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LO MANUAL INTRODUCTION 



Welcome to the R6500 Microcomputer System user family. This Programming 
Manual ia designed to work in conjunction with the R6500 System Hardware 
Manual, which describes the basic hardware considerations when using the 
Rockwell International microcomputer family. 

Before reading this Programming Manual, it is suggested that the reader 
acquaint himself with the Hardware Manual in order to understand the compo- 
nents available in the R6500 system and how these components are interconnected 
to form the R6500 system. This Programming Manual develops the concepts of 
microprocessor (CPU) internal architecture and how it is used, with attention 
given to input/output considerations. Familiarity with the hardware will 
facilitate easier understanding of these important concepts. 

In order to best serve the total customer base, this manual is written in 
two levels. The first is a very basic introduction to the R6500 system, and 
the second level is for the user who has to refer to the manual on more than 
an occasional basis and who wants to rapidly scan and find specific sections. 
For the user who is quite familiar with programming and the R6500 instruction 
Bet, the appendices are the best references in the sense that they summarize. 
In a series of tables for convenience, all of the data which are discussed in 
detail In the manual. 

It is recommended that even the user who is an experienced programmer and 
familiar with microprocessors still take the time to read through the manual 
In detail. Some of the architectural concepts are different from those found 
in second-generation machines, and this manual instructs the user how to opti- 
n"*.ze the utilization of the microprocessor, while providing an introduction of 
Its basic concepts. 
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Criticism of this manual is welcomed at all times. Of particular 
interest are cases where the user was unable, by use of the index and appen- 
dix, to rapidly find the answer to a question developed in the course of 
designing a microprocessor system. Welcomed also are any comments which will 
enhance the content and format of the manual in future editions or addenda- 

1.1 MICROPROCESSOR ARCHITECTURE 

The R6502 through R6507 and R6512 through R6515 are all 8-bit micro- 
processors. That means that 8 bits of data are transferred or operated upon 
during each instruction cycle or operation cycle. 

All devices in the R6500 family operate on data 8-bits-at-a-time , al- 
though some of the operations will appear to be serial or 16-bit-wide oper- 
ations. A later section of this manual discusses the lise of sequential oper- 
ations on an 8-bit basis and how one can accomplish 16-bit effective operands 
and addressing. 

For some time, the computer industry has been designating 8-bit combina- 
tions of data by a term known as a %yte." In many large comnuters which 
operate simultaneously on multiple bytes of data, the number of bytes which 
are transferred and operated on by the machine in parallel are called a 
"word." Because the R6500 Microcomputer System's microprocessors are 8-bit 
microprocessors, the words and bytes are of equal length. Therefore, for 
convenience through the discussion of the basic 8-bit processors, "byte" and 
"word" will be used synonymously. 
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CHAPTER 2 



THE DATA BUS, ACCUMULATOR AND ARITHMETIC UNIT 



2,0 THE DATA BUS 



Although most of the following discussion will consider how one 
operates with a general-purpose register called the accumulator, it must 
be understood that data has to transfer between the accumulator and out- 
side sources by means of passing through the microprocessor to 8 lines 
called the data bus. The outside sources include the program which con- 
trols the microprocessor, the memory which will be used as interim stor- 
age for internal registers when they are to be used in a current opera- 
tion, and the actual communications to the world through input/output (I/O) 
ports. Later in this document performance of transfers to and from each 
of these devices will be discussed. However, at present, discussion 
will center on the microprocessor itself. 



DATA BUS (8-BIT PARALLEL) 



ACCUMULATOR 
A 



MEMORY 
M 



Partial Block Diagram of a R6500 Microcomputer System Microprocessor 
FIGURE 2.1 

The only operation of the data bus is to transfer data between mem- 
ory and the processor's internal registers such as the accumulator. Fig- 
ure 2.1 disolays the basic communication between the accumulator. A, and 
the memory, H, through the use of eight bidirectional data lines called 
the "data bus." 
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2. J THE ACCUMULATOR 



The accumulator is a register in which data are kept on which opera- 
tions are performed. All operations between memory locations must be 
communicated through the accumulator or one of the auxiliary index reg- 
isters. The accumulator is used as a temporary storage in moving data 
from one inepiory location to another. Therefore, the first use for the 
accumulator (A) is simply in the transfer of data from memory to the accu- 
mulator or from the accumulator to memory. One can hrin^ datpi into the 
accumulator, perform operations such as AND/OR on the data, test the re- 
sults of those operations, set new bits in the accumulator, or transfer the 
data back out to the outside world. 

The accumulator serves as an interim storage for a series of oper- 
ations such as adding two values together, with one of the values being 
loaded into the accumulator, the second added to it, and the results stored 
in the accumulator. The accumulator really serves two functions', 1) It is 
one of the primary storage points for the machine, and 2) it is the point 
at v;hich intermediate results are normally stored. 

2.1.1 LDA — Load Accumulator with Memory 

V/hen instruction LDA is executed by the microprocessor, data 
are transferred from memory to the accumulator and stored in the 
accumu la tor . 

Rather than continuing to give a word picture of the opera- 
tion, introduced will be the symbolic representation M -* A, where 
the arrow means "transfer to." Therefore, the LDA instruction sym- 
bolic representation is read ''memory transferred to the accumulator." 

LDA affects the contents of the accumulator, does not affect 
the carry or overflow flags; sets the zero flag if the accumulator is 
zero as a result of the LDA, otherwise resets the zero flag; sets the 
negative flag if bit 7 of the accumulator is a 1 , otherwise resets the 
nega t ive flag . 

Although yet to be developed is the concept of addressing 
modes, for reference purposes LDA is a "Group One" instruction and has 
all of the major addressing modes of the machine available to It as 
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stated In Appendix A. These addressing modes include Immediate; 
Absolute; Zero Page; Absolute, X; Absolute. Y; Zero Page, X; Indexed 
Indirect; and Indirect Indexed. 

2.1.2 STA — Store Accumulator in Memory 

This instruction transfers the contents of the accumulator 
to memory. 

The symbolic representation for this instruction is A M. 

This instruction affects none of Che flags in the processor 
status register and does not affect the accumulator. 

It is a "Group One" instruction and has the following address- 
ing modes available to it: Absolute: Zero Page; Absolute, X: Abso- 
lute, Y; Zero Page, X; Indexed Indirect; and Indirect Indexed. 
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2.2 THE ARITHMETIC UNIT 

One of the functions to be expected from any computer is the ability 
to compute or perform arithmetic operations. Even In a simple control 
problem, one often finds it useful to add two numbers in order to determine 
that a value has been reached, or to subtract two numbers in order to calcu- 
late a new value which must be obtained. In addition, many problems involve 
some rudimentary form of decimal or binary arithmetic; certainly, many appli- 
cations will involve both. The R6500 has an 8-bit arithmetic unit which 
interfaces to the accumulator as shown in Figure 2.2. 



21 



DATA BUS 
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2E 



ARITHMETIC 
LOGIC 
UNIT 
ALU 



ACCUMULATOR 
A 



MEMORY 
M 



Partial Block Diagram Including Arithmetic Logic Unit of a R6500 Computer System Microprocessor 

FIGURE 2.2 



The arithmetic unit is composed of several major parts. Tlie most 
important of these is the circuitry necessary to perform a two's comple- 
ment add of 8-bit parallel values and to f»,enerate an 8-paral lel-bit binary 
result plus a carry. A review of binary and binary-coded dec imal (BCD) 
arithmetic is presented in Appendii: H. However, a quick review of the 
concept of "carry" is in order. The largest range that can be repre- 
sented in an 8-bit number is 256, with values ranging between and 255. 
If we add any two numbers which result in a sum which is greater than 255, 
we represent the result with a ninth bit plus the 8 bits of the excess 
over 255. The ninth bit is called "carry." 
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2.2.1 ADC — Add Memory to Accumulator with Carry 



This instruction adds the value of memory and carry from the 
previous operation to the value of the accumulator and stores the 
result in the accumulator. 

The symbolic representation for this instruction is 
A + M + C A. 

This instruction affects the accumulator. It sets the carry 
flag when the sum of a binary add exceeds 255 or when the sum of a 
decimal add exceeds 99; otherwise carry Is reset. The overflow flag 
is set when the sign or bit 7 is changed due to the result exceeding 
+127 or -128; otherwise overflow is reset. The negative flag is set 
if the accumulator result contains bit 7 on; otherwise the negative 
flag is reset. The zero flag is set if the accumulator result is 0; 
otherwise the zero flag is reset. 

It is a "Group One" instruction and has the following address- 
ing modes: Immediate; Absolute; Zero Page; Absolute, X; Absolute, Y* 
Zero Page , X; Indexed Indirect ; and Indirect Indexed , 

The ninth bit of the result is stored in the carry flag and 
the remaining 8 bits reside in the accumulator. The carry flag can 
be thought of as a flag bit which is remote from the accumulator it- 
self, but which is directly affected by accumulator operations as 
though it were a ninth bit In the accumulator. The primary reason 
for not viewing the carry bit as merely a ninth bit in the accumu- 
lator is that one has program control over its state by being able 
to set (to "1") or clear (to "0") the bit and, of course, it is not 
part of the 8-bit accumulator In data transfer operations. Examples 
employing the Add with Carry operation follow. 

Example 2.1 : Add 2 Numbers with Carry; No Carry Generation 



0000 


1101 


13 = 


(A)* 


1101 


0011 


211 - 


(M)* 




1 


1 - 


CARRY 


1110 


0001 


225 = 


(A) 



*(A) and (M) refer to the 'contents" of the accumulator and 
"contents" of memory respectively. 
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Example 2.2 : Add 2 Numbers with Carry; Carry Generation 

1111 1110 254 - (A) 

0000 Olio 6 = (M) 

1_ 1_ = CARRY 

0000 0101 5 = (A) 

While the accumulator contains "5," the carry flag signals 
the user that the result exceeded 255 and. therefore, the result can 
be properly interpreted as 256 + 5 = 261. 

2.2.1.1 Multiple-Precision Addition 

To perform the addition of two numbers, one issues to the 
microprocessor an ADC instruction which adds the memory and the accu- 
mulator, and stores the results in the accumulator v/ith the carry bit 
being set if the results exceed 255. 

To add numbers with significantly higher value than 255. it 
would be necessary to represent these numbers by a series of serial 
8-bit numbers. With the 16 bits in two serial 8-bit numbers, it is 
possible to represent binary numbers of greater than 65.000 in value. 
In order to add two 16-bit numbers together and thus accomplish double 
precision addition, one first loads the lowest byte of one number into 
the accumulator, clears the carry flag and then adds the second number 
to the first number in the accumulator using the ADC command. One 
then stores this result into another memory location using the STA 
command. The carry flag now represents the carry from the lowest byte 
to the highest byte. One can then load the high-order byte of the 
first number, add with carry again to the high value of the second num 
ber. and store the result in the high-order byte of the result. Thus, 
it can be seen that the carry allows us to perform as much precision 
arithmetic as is necessary. The example listing below displays the 
commands used to execute the addition of two 16-bit numbers. 



Carry 



HI 
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Example 2.3 : Adding Two 16-Bit Numbers 

High-Order-Byte Low-Order Byte 
First Number Hi 

Second Number H2 L2 

Result of Addition H3 

LDA LI Load low-order byte, first number 

CLC Clear carry flag (carry = 0) 

pjQQ L2 Add LI to low^rder byte, second num- 

ber 

STA L3 Store result in memory, carry flag is 

still set if set in ADC operation 

LDA HI Load high-order byte, first number 

yy)C H2 Add HI and carry value from first ADC 

operation to high-order byte, second 
number 

STA H3 Store result in memory 

In this example it was necessary to clear the carry flag 
before starting the add instruction. This, of course, means that 
commands exist that set and clear the carry flag allowing for addi- 
tion without values generated from the prior operation. One could 
also, at the end of the program, check to see if the result exceeded 
16 bits by testing the carry flag. Exactly how one alters and tests 
flags will be discussed in the Flag and Branches Sections, The 
examples below display the concept of carry from the addition of the 
low order bytes. 

Example 2.4 : Add Two 16-Bit Numbers. No C arry from Low- 
Order Add 

0000 0001 0000 0010 258 

0001 0000 0001 0000 4112 

Add low-order bytes: (clear carry) 

0000 0010 (A) 

0001 0000 (M) 

Carry = /O/ 0001 0010 (A) 

Add high-order bytes (carry = 0) : 

0000 0001 (A) 

0001 0000 (M) 
CARRY 

Carry = /o/ 0001 0001 (A) 

Result = 0001 0001 0001 0010 = 4370 
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Example 2.5 : Add Two 16-Bit Numbers, with Ca rry From Low- 



Order Add 



0000 0001 1000 0000 

0000 0000 1000 0000 128 

Add low-order bytes: (clear carry) 

1000 0000 (A) 
1000 0000 (M) 
Carry = jTJ 0000 0000 (A) 

Add high-order bytes: (carry = 1) 

0000 0001 (A) 

0000 0000 (M) 

_1 CARRY 

Carry = /O/ 0000 0010 (A) 

Result = 0000 0010 0000 0000 = 512 



2.2.1.2 Signed Arithmetic 

It is possible to look at the add operation and the way 
data are represented in memory in a different way. If, in the 16-bit 
problem (Examples 2.4 and 2.5), one were working with 15 bits of pre- 
cision (in other words, 15 bits of valid data) plus 1 bit of sign (0 
for positive and 1 for negative), it would be possible to perform 
signed binary arithmetic without changing the adder, but by merely 
changing the way the results are interpreted. In order to facilitate 
this concept, the microprocessor has the ability to represent positive 
or negative numbers by means of a negative flag which will be discussed 
length in Section 3.7. In the R6500 microprocessor family, bit 7 is 
the sign position bit. This means that the highest-order byte in a 
series of bytes should have the sign i^ the eighth position. If, for 
simplicity, one talks about signed 8-bit numbers, it would, mean that 
one was allowed only 128 combinations of each sign because that is the 
most that can be represented in 1 bits, with the eighth bit or the 
highest bit reserved for the sign position. 
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7 5 5 4 3 2 1 ^ BIT POSITION 



SIGN POSITION 



"1" 
-0" 



= NEGATIVE 
- POSITIVE 



Byte Orientation with Sign Position 
FIGURE 2 3 



In the following examples of signed arUhmeric it should oe 
noted that nneraMons are occurring on a 7-blt field of numbRr,s and 
that any carry generated out of that field wl.11 reside in the eighrh 
bit — not in the carry flag discussed during the add operations. The 
generation of a carry out of the field is the same as when adding two 
B-bit numbers, except for the fact that the normal c.iiry f^a,, does not 
correctly represent the fact that the field has been exr.M (!••.:. This is 
because the true carry from adding the two 7^bit numh r. " r .-sides in the 
sign bit position. Therefore, the carry flag has no l^jI meaning. In- 
stead, there is a separate flag, the overflow flag, which is used to 
indicate when a carry from 7 bits has occurred and allows the user to 
write correction programs. 

In each example, the negative numbers are in two's romplemenr 
form. Also included in each result will be the status of the carry 
and overflow flags. The overflow flag is set whenever the sign bit 
(bit 7) is changed as a result of the operation. 

Example 2.6: Add Two Positive Numbers with No Overflow 

0000 0101 +5 (A) 

0000 0111 +7 (M) 

Carry = [oj 0000 UOO +12 (A) 

Overflow = /o7 "0" in bit 7 indicates oosltive result. 

Note that both the carry and overflow 
flag remain cleared. 
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Example 2.7: Add Two Positive Numbers with Overflow 



QUI 1111 +127 (A) 

t 0000 POLO + 2_ (M) 

Carry = /Of 1000 0001 "-127" (A) 

Overflow = /T/ "1" In bit 7 Indicates negative result and 
the two's complement of the result Is 127; 
however, the overflow flag Is set Indicat- 
ing the allowable range was exceeded In the 
addition. 



Therefore, examination of the overflow indicated that the result was 
in fact not negative but that the bit 7 position represented an over- 
flow beyond the value of 127. Hence the user is flagged of an incor- 
rect result and a correction routine (program) must follow. 

Example 2.8 : Add P ositive and Negative Numbe r with Posi- 
t ive Result 



0000 


0101 


+5 




1111 


1101 


-3 


(M) 


0000 


0010 


+2 


(A) 



Overflow = /o/ "O" in bit 7 indicates positive result. 

(Recall that though the carry flag is set, 
it has no meaning in signed operations.) 

Exampl e 2.9 : Add Posi ti ve and Ne&ative Number with Negative 
Result 



0000 


0101 


+5 


(A) 


nil 


1001 


-7 


(M) 


1111 


1110 


-2 


(A) 



Overflow = /O/ "1" in bit 7 indicates negative result. 
Example 2.10 : Add Two Negative Numbers without Overflow 

nil 1011 -5 (A) 

nil 1001 -7 (M) 

Carry = /!_/ HU 0100 -12 (A) 

Overflow = JOJ "1" in bit 7 indicates negative result. 
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Example 2.11: Add T wo Negative Numbers with Overflow 



1011 1110 -66 (A) 
_ lOU nil -65 (M) 
Carry = /I/ 0111 1101 "+125" (A) 

Overflow « /U "0" Indicates positive result, but the 

overflow flag is set indicating that the 
allowable range was exceeded In the opera- 
tion. Without the overflow indication, the 
result would be Interpreted as +125. The 
overflow, however, indicated that the result 
was negative and exceeded the value -128, 
Hence the user is flagged of an incorrect 
result, indicating the need for a correc- 
tion routine. 



2.2.1.3 Decimal Addition 

There is a way for the user to organize data for decimal 
operations. The R6500 System's microprocessors have a modified 
adder which allows the user to represent his numbers as two 4-bit 
binary coded decimal (BCD) numbers packed into a single byte. This 
is a unique feature of the R6500 microprocessor family in that the 
operation in the following example can be performed. 

Example 2. 12 : Decimal Addition 



CLC 






Clear Carry Flag 


SED 






Set Decimal Mode 


LDA 


0111 


1001 


79 


ADC 


0001 


0100 


+14 


STA 


1001 


0011 


93 



The microprocessor adder has the unique capability of per- 
forming real time correction to the normal expected binary result 
without any direct interference from the programmer. Other popular 
microprocessors require a separate instruction (Decimal Adjust) 
which corrects the direct binary result of the arithmetic unit to 
obtain the same final results as are available on this microprocessor 
directly . 

In order to make the same arithmetic unit perform either as 
a binary adder or as a decimal adder, the user chooses the mode In 
which he is going to operate (either decimal or binary) by setting 
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another flip-flop In the microprocessor called the "decimal flag". As 
shown in this example, one not only initiali.es the adder by clearing 
the carry 'flag, but also pats the processor into decimal mode with 
the SED instruction. Even though this also requires one instruction, 
it is possible to put the machine in decimal mode once and perform 
man> long strings of decimal numbers without further user interven- 
tion The "Decimal Adjust" feature on other microprocessors requires 
programming subsequent to each binary operation. The CLD instruction 
returns the arithmetic unit to the binary adder mode. 

2.2.1. A Add Summary 

' In summary, the basic arithmetic unit is a binary adder 
which, under control of the ADC command, performs binary arithmetic 
on the accumulator and data, storing the result in the accumulator. 
Depending on the way the user looks at the data which are presented 
to the adder and the results which are obtained, the user can deter- 
mine whether or not the result exceeds 255 binary or 99 decimal; he 
can perform precision arithmetic by use of the ninth bit or carry 
flag: he can control whether or not the microprocessor is a decimal 
adder by setting the decimal mode; and he can represent his numbers 
as signed binary numbers by analyzing other flags that are set- in the 
machine . 

2.2.2 SBC Subtract Memory fro m Accumulator with Borrow 

This instruction subtracts the value of memory and borrow from 
the value of the accumulator, using two's complement arithmetic, and 
stores the result in the accumulator. Borrow is defined the carry 
flag complemented; therefore, a resultant carry flag indicates that a 
borrow has not occurred. 

The symbolic representation for this instruction is 

;^ _ M - C A. 

This instruction affects the accumulator. The carry flag is 
set if the result is greater than or equal to 0. The carry flag Is 
reset when the result is less than 0. indicating a borrow. The over- 
flow flag is set when the result exceeds +127 or -128; otherwise, It 
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is reset. The negative flag is set if the result in the accumulator 
has bit 7 on, otherwise it is reset. The Z flag is set if the result 
In the accumulator is 0; otherwise, it is reset. 

It is a "Group One" instruction. It has addressing modes 
Immediate; Absolute; Zero Page; Absolute, X; Absolute, Y; Zero Page, X; 
Indexed Indirect; and Indirect Indexed. 

In a binary machine, the classical way to perform arithmetic 
Is by using two's complement notation. In using two's complement 
notation, any subtraction operation becomes a sequence of bit comple- 
mentations and additions. I^is reduces the complexity of the circuits 
required to perform a subtraction. 

When the SBC instruction is employed in single-precision subtrac- 
tion, there will normally be no borrow; therefore, the programmer 
must set the carry flag, by using the SEC (Set carry to 1) instruc- 
tion, before using the SBC instruction. The microprocessor adds the 
carry flag to the complemented memory data, resulting in a true two's 
complement form of the memory value with its sign inverted. 

Example 2.13: Subtract Two Numbers with Borrow ; Positive Result 
Assume a single precision subtraction where A contains 5 and M con- 
tains 3. The carry flag must be set to a 1 using the SEC instruc- 
tion, thereby representing the no-borrow condition. 

The adder changes the sign of M by taking the two's complement 
of M. This Involves complementing M and adding the carry bit. 

M - 3 0000 0011 
Complemented M HH HOO 

Add C - 1 L 

-M » -3 1111 1101 
The adder adds A and the two's complement -M together. This 
operation occurs simultaneously with the complement operation. 
A = 5 0000 0101 
Add -M - -3_ 1111 1101 
Carry - /I/ 0000 0010 - +2 

The presence of the carry flag after this operation indicates 
that No Borrow was required, therefore the result is +2. 
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Examp 1 e 2.14: Subtract Two Numb e rs w ith Borrow; Negative ResuU 

Assume a single-precision subtraction where A contains 5 and M con- 
tains 6. Set the carry flag to a 1 with SEC to indicate No Borrow. 

M - 6 0000 0110 

Complemented M 1111 1001 

Add C ' 1 1 

-M - -6 1111 1010 

A = 5 0000 0101 
Add -M ^-6 1111 1010 
Carry - /O/ 1111 1111 = -1 

The absence of the carry flag after this operation indicates 
that a borrow was required, therefore the result Is a -1 in two's 
complement form. The absolute (unsigned) result in straight binary 
could be obtained by taking the two's complement of this number. 

2.2.2.1 Multiple-Precision Subtraction 

Double-precision subtraction is implemented in a fashion 
similar to addition. An example for subtracting a 16-bit number and 
storing the result follows: 

t Example 2.15 : Subtracting Two 16-Blt Numbers 

High-Order Byte Low-Order Byte 

First Number HI LI 

Second Number H2 L2 

Result of Subtraction H3 L3 

SEC Set Carry 

LDA LI Load-Low Order Byte, First Number 

SBC L2 Subtract with Borrow, Low-Order Byte" of Second 
Number from LI 

STA L3 Store Result in Memory 

LDA HI Load High-Order Byte, First Number 

SBC H2 Subtract with Borrow, High-Order Byte of Second 
Number from HI 

STA H3 Store Result in Memory 
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Example 2. 16 : Subtract In Double- Precision Format; Positive 
Result 

Assume a double-precision subtraction where 255 is to be 
subtracted from 512 for an example. Since there has been no borrow 
coming into this subtraction operation, the carry flag must be set. 

Following are che 2 numbers in binary form: 

High-Order Byte Low-Order Byte 

A field = 512 0000 0010 0000 0000 

M field = 255 0000 0000 1111 1111 

Since the adder can only operate on single byte numbers, the 

programmer must operate on the low-order bytes first. 

M = 1111 1111 
Complemented M = 0000 0000 

Add C = 1 1 

-M 0000 0001 

A = 0000 0000 
Add -M_= 0000 0001 
Carry - /£/ 0000 0001 

The carry is brought over to the subtract operation on the 

high-order bytes. 



M = 


0000 


0000 


Complemented M = 


1111 


1111 


Add C = 







-M 


1111 


1111 


A = 


0000 


0010 


Add -M = 


1111 


1111 



Carry = /!./ 0000 0001 
The result in binary form follows: 

Carry = /I/ 0000 0001 0000 0001 = +257 

The presence of the carry flag after the highest-order byte 
subtraction indicates that the entire number required No Borrow, 
therefore it Is a positive number in straight binary form. 
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Example 2,17: Subtract in Double Precision Format; Negative 
Result 

Now assume a double-precision subtraction where 512 is to be 
subtracted from 255. Again, since there has been no borrow coming 
into this subtraction operation, the carry flag must be set. 

Following are the two numbers in binary form: 

High-Order Byte Low-Order Byte 

A field = 255 0000 0000 1111 1111 

M field = 512 0000 0010 0000 0000 

Operating on the low-order byte: 

M = 0000 0000 

M = 1111 1111 
Add C = 1_ 1 
Carry = /I/ 0000 0000 = -M 

A_= 1111 1111 
Add -M - /!/_ 0000 0000 
Carry = /I/ IHI HH 
The presence of the carry = 1 indicates no borrow. 
The carry is now brought over to the high-order byte sub- 
tract operation: 



Add C 



M = 


0000 


0010 


M = 


1111 


1101 


1 




1 




1111 


1110 


A = 


0000 


0000 


C = 


1111 


1110 


101 


1111 


1110 



Carry 

I 

The result in binary form is: 

Carry = foj 1111 1110 1111 1111 = -257 
Carry = (0/ indicates the presence of a borrow, therefore 
the number is negative and is in two's complement form. 

2.2.2.2 Signed Arithmetic 

Signed numbers can be subtracted, using the SBC instruction, 
just as easily as they can be added. The microprocessor converts the 
numbers from memory to its two's complemented form and then adds it 
to the value of the accumulator just as it does in an unsigned 
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subtract described in Section 2.2.2. The addition operation is 
identical to that described, and to the examples given in Section 
2.2.1,2 

It should be remembered that before using the SBC instruc- 
tion, either signed or unsigned, the carry flag must be set to a 1 in 
order to indicate a no borrow condition. The resultant carry flag 
has no meaning after a signed arithmetic operation. 



2.2.2.3 Decimal Subtract 

As indicated in Section 2.2.1,3, it is possible to repre- 
sent numbers as packed 4-bit BCD numbers. In this case, which is 
again unique to this microprocessor, it is possible to make the adder 
act as though it were a decimal adder. In this case, the functifcn of 
the machine is one of correcting for the subtraction of positive num- 
bers by complementing the number, setting the carry and performing 
binary arithmetic with an automatic correction at the time the result 
is stored in the accumulator. The unique capabilities of this adder 
give the results as shown in the next example. 

Example 2.18 : Decimal Subtraction 



SED 






Set 


Decimal Mode 


SEC 






Set 


Carry Flag 


LDA 


0100 


0100 


44 




SBC 


0010 


1001 


29 




STA 


0001 


0101 


15 





By setting the decimal mode and setting the carry flag, one can sub- 
tract number 29 from number 44 with the results in the accumulator 
automatically being 15. 

As has been indicated, one can perform both addition and 
subtraction when the machine is set in decimal mode, treating the 
bytes to be added as unsigned, positive, binary-coded digits. In 
addition the carry flag represents the case when the result in the 
number exceeded 99, and in subtraction the absence of the carry flag 
represents a true borrow situation. 
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2.2.3 Carry and Overflow DurinR Arithmetic Operations 



It Is necessary to set or reset the carry flag prior to the ■ 

beginning of any arithmetic instruction. Because the carry flag is ■ 

set or reset as a result of the arithmetic operation at the end of I 

the loop, one. can test the flag to determine whether or not a carry I 
or a borrow occurred in the operation. By proper use of the overflow I 

flag one can treat the high-order bit of any set of bytes as a sign I 

bit as long as the results of the negative numbers are carried in I 

two's complement form. The microprocessor also sets the overflow I 

flip-flop to indicate when a result larger than can be stored in a I 

7-bit field has occurred and when the resultant sign is incorrect. I 

In binary arithmetic the carry flag set indicates results in excess I 

of 256. and in decimal arithmetic indicates results in excess of 99. I 

Although the input carry is very important to these operations, a I 

simple rule is: Set the carry flag prior to subtract; clear the | 

carry flag prior to add . 1 

2. 2. A Logical Operands K 
In implementing a parallel binary adder there are several use- I 
ful logic functions which are subsets of a binary add operation. In i 
the R6500 System's microprocessor family, these subsets are employed tl 
implement the logical operands "AND." "OR." and "EOR" (Exclusive Or). I 
These operations are used to test and control bit manipulations. I 

2.2.4.1 AND — Memory with Accumulator « 
The AND instruction transfers the accumulator and memory to I 
the adder which performs a bit-by-bit AND operation and stores the I 
result back in the accumulator. ft 

This instruction affects the accumulator; sets the zero flag! ^ 
if the result in the accumulator is 0. otherwise resets the zero f lagl ^ 
sets the negative flag if the result in the accumulator has bit 7 on,l| 
otherwise resets the negative flag. 1| 
This is symbolically represented by A A M A. 
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AND is a "Group One" instruction having addressing modes of 
Immediate; Absolute; Zero Page; Absolute. X; Absolute. Y; Zero Page. X 
Indexed Indirect; and Indirect Indexed. 

One of the uses for the AND operation is that of resetting a 
bit in memory. In the example below. 

Example 2.19 : Clearing a Bit with AND 

LDA 1100 Xlll. where X is or 1 

AND 1111 0111 

STA 1100 Dili 
a byte is loaded into the accumulator and the AND instruction resets 
the accumulator bit 3 to 0. The accumulator is then stored back into 
memory, thereby resetting the bit. 

2.2.4.2 ORA "OR" Memory with Accumulator 

The ORA instruction transfers the memory and the accumulator 
to the adder which performs a binary "OR" on a bit-by-bit basis and 
stores the result in the accumulator. 

This is indicated symbolically by A V M A. 

This instruction affects the accumulator; sets the zero flag 
if the result in the accumulator is 0. otherwise resets the zero flag; 
sets the negative flag if the result in the accumulator has bit 7 on. 
otherwise resets the negative flag. ORA is a "Group One" instruction. 
It has the addressing modes Immediate; Absolute; Zero Page; Absolute, 
Absolute, Y; Zero Page. X; Indexed Indirect; and Indirect Indexed. 

To set a bit, the OR instruction is used as shown below: 

Example 2.20 : Setting a Bit with OR 

LDA 1110 Xlll, where X is or 1 
ORA 0000 1000 
STA 1110 1111 

2.2.4.3 EOR — "Exclusive OR" Memory with Accumulator 

The EOR instruction transfers the memory and the accumulator 
to the adder which performs a binary "EXCLUSIVE OR" on a blt-by-bit 
basis and stores the result in the accumulator. 
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This is indicated symbolically by A VM -> A. 

This instruction affects the accumulator; sets the zero flag 
if the result in the accumulator is 0, otherwise resets the zero flag; 
sets the negative flag if the result in the accumulator has bit 7 on, 
otherwise resets the negative flag. 

EOR Is a "Group One*' instruction having addressing modes of 
Immediate; Absolute; Zero Page; Absolute. X; Absolute, Y; Zero Page, X 
Indexed Indirect; and Indirect Indexed. 

One of the uses of the EOR instruction is in complementing 
bytes. • This is accomplished below by exclusive ORA-ing the byte with 
all l»s. 

Example 2.21 : Complementing a Byte with EOR 

LDA 1010 1111 
EOR 1111 1111 
STA 0101 0000 
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CHAPTER 3 



CONCEPTS OF FLAGS AND STATUS REGISTER 



One can view each of the individual flags or status bits in the 
machine as individual flip-flops. The carry flag can be considered the 
ninth bit of an arithmetic operation. The decimal mode flag is set and 
cleared by the user and used by the microprocessor to select either binary 
or decimal mode. For programming convenience the microprocessor treats 
all of the flags or status bits as component bits of a single 8-bit reg- 
ister. In Figure 3.1 the processor status register (or "P" register) is 
added to the block diagram. 




DATA BUS 



ACCUMULATOR 
A 



31 



PROCESSOR 
STATUS 
REGISTER 
P 



31 



MEMORY 
M 



Parlial Block Diagram of a R6500 Microcomputer System Microprocessor Incitulin^ PRef^isters 

FIGURE 3.1 



Each of the individual flags or bits has its own particular meaning in the 
microprocessor as defined in Figure 3.2 
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Processor Status Register "P" 
FIGURE 3.2 



PROCESSOR STATUS REGISTER 
CARRY 

ZERO RESULT 
INTERRUPT DISABLE 
DECIMAL MODE 
BREAK COMMAND 
EXPANSION 
OVERFLOW 
NEGATIVE RESULT 



3.0 CARRY FLAG (C) 

The carry bit which is modified as a result of specific arithmetic 
operations or by a set or clear carry command has been discussed previous! 
In the case of shift and rotate instructions, the carry bit is used as a 
ninth bit as it is in the binary arithmetic operation. The carry flag can 
be set or reset by the programmer, A SEC instruction will set and a CLC 
instruction will reset the carry flag. Operations which affect the carry 
are ADC, ASL, CLC, CMP. CPX, CPY, LSR, PLP. ROL, ROR, RTI, SBC, and SEC. 

3.0.1 SEC — Set Carry Flag 

This instruction initializes the carry flag to a 1 . This op- 
eration should normally precede a SBC loop. 

This instruction affects no registers In the microprocessor 
and no flags other than the carry flag which is set. 
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3.0.2 CLC -- Clear Carry Flag 

This Instruction initializes the carry flag to a 0. This op- 
eration should normally precede an ADC loop. 

This instruction affects no registers in the microprocessor 
and no flags other than the carry flag which is reset. 

3.1 ZERO FLAG (Z) 

This flag is automatically set by the microprocessor during any data 
movement or calculation operation when the 8 bits of results of the opera- 
tion are 0. Therefore, the bit is on ("1") when the results are 0, and 
off ("0") when the results are not equal to 0, The feature of the machine 
is similar to that of the PDPll in the sense that operations which are 
decrementing (or incrementing) index registers or memory locations have 
a built-in test for as a result of decrementing (or incrementing) to 
the condition. It is also possible to test for condition immediately 
following load and other logical operations, as opposed to processors 
which have to do a test and branch instruction. The Z flag is not 
directly settable or resettable by an instruction but is affected by the 
following Instructions: ADC, AND, ASL, BIT, CMP, CPY, CPX, DEC, DEX, DEY, 
EOR, INC, INX, IhTY, LDA, LDX, LDY, LSR, ORA, FLA, PLP, ROL, ROR, RTI, SBC, 
TAX, TAY, TXA, TSX AND TYA. The Z flag is not updated after a resulting 
decimal addition or subtraction (ADC, SBC). 

3.2 INTERRUPT DISABLE (I) 

The interrupt disable is a flip-flop made use of by the programmer 
and by the microprocessor to control the operations of the interrupt re- 
quest pin. A more detailed discussion of the effects of the interrupt 
disable are given in the discussion under interrupt control. However, the 
purpose of the interrupt disable is to disable the effects of the interrupt 
request pin (IRQ). The interrupt disable, I, is set by the microprocessor dur- 
ing reset and interrupt commands. The I bit is reset by the CLI instruc- 
tion or the PLP instruction, or at a return from interrupt in which the 
interrupt disable was reset prior to the interrupt. The interrupt flag 
may be set by the programmer using a SEI instruction and is cleared by the 
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programmer with a CLI instruction. Instructions which affect the 
interrupt disable are BRX, CLI. PLP, RTI and SEI. 



3.2.1 SEI — Set Interrrupt Disable 

This instruction initializes the interrupt disable to a 1 . It 
is used to mask interrupt requests during system reset operations and 
during interrupt commands. 

It affects no registers in the microprocessor and no flags 
other than the interrupt disable which is set. 

SEI is a single-byte instruction and its addressing mode is 
Implied . 



3.2.2 CLI — Clear Interrupt Disable 

This instruction initializes the interrupt disable to a 0. 
This allows the microprocessor to receive interrupts. 

It affects no registers in the microprocessor end no flags 
other than the interrupt disable which is cleared. 

CLI is a single-byte instruction and its addressing mode is 
Implied . 



J. 3 DECIMAL MODE FLAG (O) 

As discussed, the purpose of the decimal mode flag is to control whetl 
or not the adder operates as a straight binary adder for add and subtract 
instructions, or as a decimal adder for add and subtract instructions. The 
SED instruction sets the flag and the CLD instruction resets it. The only 
instructions which affect the decimal mode flag are CLD, PLP , RTI and SED. 

3.3.1 SED — Set Decimal Mode 

This instruction sets the decimal mode flag D to a 1. This 
makes all subsequent ADC and SBC instructions operate as a decimal 
arithmetic operation. 

SED affects no registers in the microprocessor and no flags 
other than the decimal mode which is set to a 1 . 
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3.3,2 CLD — Clear Decimal Mode 

This instruction sets the decimal mode flag to a 0. This 
causes all subsequent ADC and SBC instructions to operate as simple 
binary operations. 

CLD affects no registers in the microprocessor and no flags 
other than the decimal mode flag which is set to a 0. 

3A BREAK COMMAND (B) 

The break command flag is set only by the microprocessor and is used 
to determine during an interrupt service sequence whether or not the inter- 
rupt was caused by BRK command or by a real interrupt. A more detailed 
discussion of BRK is in the interrupt section. This bit should be con- 
sidered to have meaning only during an analysis of a normal Interrupt se- 
quence. There are no instructions which can set or which reset this bit. 

3.5 EXPANSION BIT 

The next bit in the flag register is an unused bit. It is most likely 
that this bit will appear to be on when one is analyzing the Mt pattern 
in the processor status register; however, no guarantee as to its state is 
made, as this bit will be used in expanded versions of the microprocessor.- 

3.6 OVERFLOWiV) 

As discussed in the section on arithmetic operations, if one is to 
look at the binary arithmetic operations as signed binary operations, there 
needs to be some indication of the fact that the result of the arithmetic 
operation has a greater value than could be contained in the 7 bits of 
the result. This bit is the overflow bit and during ADC and SBC instruc- 
tions represents a status of an overflow into the sign position. The user 
who is not using signed arithmetic can totally Ignore this flag during 
his programming; however, this flag has the same meaning as the carry to 
the user who is using signed binary numbers. It indicates that a sign 
correction routine must be used if this bit is on after an add or subtract 
using signed numbers. 
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In addition to its use for monitoring the validity of the sign bit f 
in ADC and SBC instructions, the overflow flag is dramatically different | 
from the overflow flags from PDPll and the MC6800. In each of those sys- f 
tems the overflow flag was very carefully controlled so as to allow car- I 
tain signed branches for analysis of signed numbers. These branches have 1 
been deleted- from the .R6500 System's microprocessor series because of con- | 
fusion -and difficulty often associated with using them, and, accordingly, | 
the overflow flag is applicable only to the operation of ADC and SBC, and ■ 
then only when signed numbers are being used. ■ 
However, in order to maximize the effectiveness of this testable flag I 
the RIT instruction which may be used to sample interface devices, allows I 
the overflow flag to reflect the condition of bit 6 in the sampled field. I 
During a BIT instruction the overflow flag is set equal to the content of I 
Che bit 6 on the data tested with BIT instruction. When used in this mode,! 
the overflow has nothing to do with signed arithmetic but is just another I 
sense bit for the microprocessor. Instructions which affect the V flag are I 
ADC, BIT, CLV, PLP. RTI and SBC. On certain versions of the microproces- I 
sor\he V bit will also be available for stimulus from the outside world. I 

3.6.1 CL V — Clear Overflow Flag I 
This instruction clears the overflow flag to a 0. This com- 
mand is utilized in conjunction with the set overflow pin which can 
change the state of the overflow flag with an external signal. 

CLV affects no registers in the microprocessor and no flags 
other than the overflow flag which is set to a 0. 

3.6.2 ' Determination of Overflow 

To briefly recap the concept of overflow detection, 6ne must 
understand that the machine signals an overflow based on the data 
entered to the operation and the final result. Since, with signed 
arithmetic, the range of numbers that can be represented is +127 to 
the overflow flag will never be set when numbers of opposite sign are 
added, since their result will never exceed that range. The machine 
deals with this by recognizing that for any two positive numbers, the 
"bit 7" of each is a"0,"and that for any arithmetic operation 
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yielding a result less than or equal to +127. the resultant "bit 7" 
must be a "0." If it is a 1, the overflow flag is set. 

Similarly, when two negative numbers are added, the "bit 7" of 
each is a "1" and for any result yielding a value less than or equal 
to -128. the resultant "bit" must be a "1." If it is a 0. the over- 
flow flag is set. 

Therefore, the machine recognizes by knowledge of the "bit 7" 
of each of the numbers to be added what the resultant "bit 7" must be 
in a non-overflow situation. If these conditions are not met, the 
overflow flag goes set. 

3.7 NEGATIVE FLAG (N) 

As already discussed, one of the uses of the microprocessor is to per- 
form arithmetic operations on signed numbers. To allow the user to readily 
sample the status of the sign bit (bit 7). the N flag is set equal to bit 7 
of the resulting value in all data movement and data arithmetic. This 
means, for instance, after a signed add one can determine the sign of the 
result by sampling the N flag directly rather than finding a way to iso- 
late bit 7. Although signs were the primary purpose for which the N flag 
was intended, its usefulness far exceeds that of strictly a sign bit. 
Because of every operation including simple moves and add operations the N 
bit is equal to the status of bit 7 as a result of the operation; its pri- 
mary use becomes that of an easily testable bit. Almost all single-bit in- 
structions, all interrupts and all I/O status flags use bit 7 as a sense bit. 
This allows the user to perform some type of memory access* operation such 
as Load A followed by immediate conditional branch based on the status of 
bit 7 as reflected in the N flag. Like the Z bit, this flag is not settable 
or controllable by the programmer and represents the status of the last data 
movement operation. Instructions which affect the negative flag are ADC, 
AND, ASL, BIT, CMP. CPY. CPX. DEC, DEX. DEY. EOR. INC. INX. INY. LDA. LDX. 
LDY, LSR. ORA, PLA. PLP, ROL, ROR. RTI, SBC, TAX, TAY, TSX. TXA and TYA. 
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3,8 FLAG SUMMARY 

To summarize, the microprocessor treats a series of flags or status 
bits as a single register called the "P" or "Program Status" register. 
Some of these flags are controllable only by the programmer (such as the D 
flag); others are controllable by both the user program and microprocessor 
(such as the interrupt disable flag) , Some of them are set and reset by 
almost every processor operation, such as the N and Z flags. Each of these 
flags has its own meaning to the programmer at a particular point in time. 
When combined with the concept of conditional branches, they represent a 
powerful test and jump capability not normally found in a machine of 
this magnitude. Except, perhaps, for the carry flag which is used as 
part of the arithmetic instructions, the flags by themselves have 
relatively little meaning unless one has the ability to test them. 
For this purpose a series of conditional branch instructions is designed 
into the machine. 
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CHAPTER 4 

TEST, BRANCH AND JUMP INSTRUCTIONS 



4.0 CONCEPTS OF PROGRAM SEQUENCE 

To this point, this manual has presented little discussion of how the 
microprocessor understands the instructions used to perform various arithmet 
and accumulator manipulations. However, it is appropriate that the concept 
of a program and how the microprocessor determines each instruction be de- 
veloped. More registers are required in the machine as shown in the 
figure below. 
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Although two 8-bit registers have been added, they are the only 
registers in the ir.achine that act as though they are one 16-bit reg- 
ister. They implement a concept known as "program count" or "program 
sequence", and subsequently their value will be referred to as "PC" or 
"program count". In certain operations it may be convenient to talk 
about how one affects the "program count low" (PCL) which will be the 
lower 8-bit register or the "program count high" (PCH) v/hich will be the 
higher 8-bit' register. The reason for this register's being 16 bits in 
length is that if it had only 8 bits it would be able to reference only 
256 locations. Since it is through the address bus that one accesses 
memory, the program counter which defines the addressable location 
should be as "wide" a word as possible. 

The accessing of a memory location is called "addressing". It is 
the selection of a particular eight-bit data word (byte) out of the 
65,536 possibilities for memory data locations. This selection is trans- 
mitted to the memory through the 16 address lines (ADH, ADL) of the micro- 
processor . 

For a more detailed discussion of how an individual memory byte is 
selected by the address lines, the reader is referred to Chapter 1 of 
the Hardware Manual. 

If the program counter v/ere only 1 byte and if the bit pattern which 
allows the microprocessor to choose which instruction it wants to act on 
next, such as "LDA" as opposed to an "AND", were contained in one byte of 
data, we could have only 256 program steps. Although the machine of this 
length might make an interesting toy, it would have no real practical 
value. Therefore, almost all of the competitive 8-bit microprocessors 
are designed vjith a double-length program counter. Even though some 
of the microprocessors of the R6500 Microcomputer System do not have all o 
the output address lines necessary to allov/ the user to address 65K bytes 
program (due to package pinout constraints), in all cases the program 
counter '.PC) is capable of addressing a full 65K by virtue of its 16-bit 
length. 



4.0.1 Use of Program Counter to Fetch an Instruction 



The microprocessor contains an internal timing and state con- 
trol counter. This counter, along with a decode matrix, governs the 
operation of the microprocessor on each clock cycle. When the state 
of the microprocessor indicates that a new instruction is needed, 
the program counter (program address pointer) is used to choose 
(address) the next memory location and the value which the memory 
sends back is decoded in order to determine what operation the micro- 
processor is going to perform next. 

To utilize the program counter to perform this operation cor- 
rectly, it must always be addressing the operation the user wants 
to perform next. This operation may be an instruction, or it may be 
data on which the instruction will operate. 

In the R6500 System's microprocessor family, the program counter 
is set with the value of the address of an instruction. The micro- 
processor then puts the value of the program counter onto the address bus, 
transferrins the 8 bits of data at that memory address into the instruc- 
tion decode. The program counter then automatically increments by 
one, and the microprocessor fetches further data for address operation 
necessary to complete the instruction. In the simple example below. 
Example A.l: Accessing Instru ctions _i^_th^_thc_P-^ Value 
P Counter* Location Contents 

0100** LDA *Program Counter 

0101 ADC AAHcxadccimal 

0102 STA Notation 

one can see how the program counter is used to access the instruc- 
tion secuence load A, add with carry, and store the result. In this 
example, the program counter would start out containing 0100. The 
microprocessor would read location 0100 by using the program counter 
to access memory, and would then interpret and imnlenent the LDA in- 
struction as previously described. The program counter will auto- 
matically increment by 1 on each instruction fetch, stepping to 
0101. After performing the LDA, the microprocessor would fetch the 



^-3 



next instruction addressing memory with the program counter. This 
would pick up the ADC instruction, the add would then be performed, 
the program counter which has been incremented to 0102 would be used 
to address the next instruction, STA. Tlie P counter incrementing 
once with each instruction is an oversimplified view of what actu- 
ally transpires within the microprocessor. 

The R6500 series of microprocessors (CPUs) usually require more 
than one byte to correctly interpret an instruction. The first byte of 
OiV\ instruction is called the OP CODE, and it is coded to contain the basic 
operation such as LDA (load accumulator with memory) and also the data 
necessary to allow the microprocessor to interpret the address of the di 
on which the operation will occur. In most cases, this address will 
appear i,n memory riglit after the OP CODE byte. This allows the micro- 
processor to use the program counter to access the address as well as 
the OP CODE. 

The following example shows how the program counter picks up 
the instruction and the address of data located at address 5155. 

Example A. 2 : Accessing Data Address With P-Counter Value 
P Counter Location Contents 

0100 LDA 

0101 55 

0102 51 

0103 Next Instruction 

The OP CODE appears in Location Address 0100. The code for the 55 
would appear next in Location Address 0101 and the 51 would appear 
in Location Address 0102, and the OP CODE for the next instruction 
appears in Location Address 0103. In this example, we see that the 
program counter is used not only to pick up the operation code, LDA, 
but also to pick up the address of the memory location from which 
the LDA is going to obtain its data. In this case, the program 
counter automatically is incremented three times to pick up the full 
instruction with the microprocessor interpreting each of the indivi- 
dual fetches as the appropriate data. In otlier words, the first 
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fetch is used to pick up the OP CODE, LDA, the second fetch is used to 
pick up the low-order address byte of the data, and the third fetch is 
used to pick up the high-order address byte of the data. This is the 
form in which many of the microprocessor instructions will appear, as 
it is the most simple form of addressing in the machine and allows 
referencing to any memory location. 

Assuming that the microprocessor has the ability to start the 
program counter at a known instruction, it should be fairly obvious 
that the program counter would then continue to advance from that 
location up to the maximum memory location, roll over to the least 
memory location and continue incrementing through the memory, fetch- 
ing instructions and addresses as it went. This would give us an 
interesting sequential program but one which lacked one tremendously 
powerful concept. The program would have no ability to perform tests 
or implement various options based on the results of those tests. 

In the previous section, the concept of flags which are set as 
a result of the microprocessor operations was developed. 

To use these flags, the program should be able to test them 
and then change the sequence of operations which are being performed 
depending on the result of the test. The program counter is going 
to continually put out an address, the microprocessor is going to 
fetch the instruction stored at that address and perform operations 
based on that instruction. In order to change a sequence of perform- 
ed instructions by the microprocessor, the programmer must change the 
value in the program counter. Therefore, test instructions are In- 
corporated which may result in a change of program count sequence as 
a result of performing one of the tests. The simplest way to change 
program sequence is to substitute a new value into the program counter 
location. In the R6500 System's series of microprocessors the 
simplest way to change tlie program count sequence is with a JMP 
Instruction. 
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4.0.2 JMF — Jump to New location 

In this instruction, the data from the memory location 
located in the program sequence after the OP CODE is loaded into the 
low-order byte of the program counter (PCL) and the data from the 
next memory location after that is loaded into the high-order byte 
of the program counter (PCH) . 

The symbolic notation for jump is (PC + 1)-^PCL, (PC + 2)h^PCH. 
As stated earlier, the "( )" means "contents of" a memory location. 
PC indicates. the contents of the program counter at the time the 
OP CODE is fetched. Therefore (PC + 2)-*PCH reads, "the contents of 
the program counter two locations beyond the OP CODE fetch location 
are transferred to the new PC high order byte," 

The addressing modes are Absolute and Absolute Indirect. 
The JMP instruction affects no flags and only PCL and PCH. 
The JMP instruction allows use of the program counter to access 
the new program counter value as illustrated by the following example: 

Example 4.3 : Use of JMP Instruction (Absolute Addressing Mode) 

Address Data Comments 

0100 JMP Jump to Location 3625 

0101 25 (New PCL byte) 

0102 36 (New PCH byte) 
t 3625 OP CODE Next l^nstructlon 

The program counter in the example starts out at location 100. The 
microprocessor loads a jump Instruction. The program counter auto- 
matically increments to 101 where the microprocessor picks up and 
temporarily stores the 25. The program counter automatically in- 
crements to 102 where the microprocessor picks up the 36. 

The 3625 is substituted into the program counter and is used 
to address the next instruction. Therefore, the JMP instruction 
contains within its address the new program counter location. 

Although the jump allows the change of program sequence. It 
does so without performing any test. So it is a JMP instruction that 
I |i' is employed when it is desired to change the program counter no matter 

iH; ' 

i;!™ what conditions have occurred. 
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Another JMP addressing Hode is the. InditrccL Addressing Mode. Before 
this technique can be understood, the basis of indirect addressing 
found in Chapter 6 must be reviewed. Tlie JMP Indirect instruction is 
detailed in Chapter 9. 

4.1 BRANCHING 

To allow for conditional program sequence change, eight conditional 
branch instructions are available for testing and performing optional 
changes of the program counter based on the status of the flags. To 
perform a conditional chanp,e of sequence, the microprocessor must interpret 
the instruction, test the value of a flag, and then change the P counter if 
the value agrees with the instruction. If the condition is not met, the 
program counter continues to increment in its normal fashion. Figure 4.2 
illustrates how a conditional test miglit be used. 

LOAD VALUE 1 

r 



ADD VALUE2 



BRANCH TO NEW 
PROGRAM COUNTER 
LOCATION 




CONTINUE IN 
PROGRAM SEQUENCE 



Use of Conditional Test 
FIGURE 4.2 
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In this example, it is seen that generation of a carry from the add 
operation will allow an out-of-sequence branch to a new location. 



A. 1.1 Basic Concept of Relative Addressing 

If one considers that the instruction JMP required three 
bytes, one for OP CODE, one for new program counter low (PCL), and 
one for new program counter high (PCH)^ it is seen that jump on carry 
set would also require three bytes. Because most programs for con- 
trol require many continual jumps or branches, the R6500 Series uses 
"relative" addressing for all conditional test instructions. To 
perform any branch, the program counter must be changed. In rela- 
tive addressing, however, we add the value in the memory location 
following the OP CODE to the program counter. This allows us to 
specify a new program counter location with only two bytes, one 
for the OP CODE and one for the value to be added. 

To illustrate this, in the following example, the branch on 
carry set (BCS) illustration is followed by a value of 50. If the 
carry is set, the new program location would be 108 + 50 - 158; in 
other words, it will take the branch. 

Example 4. A : Illustration of "Branch on Carry Set" 



Address 


Data 


Comments 


0100 


LDA 


Load First Value 


0101 


ADLl 


First Number, Low Byte 


0102 


ADHl 


First Number, High Byte 


0103 


ADC 


Add Second Value 


OlOA 


ADL2 


Second Number, Low Byte 


0105 


ADH2 


Second Number, High Byte 


0106 


BCS 


Test for Carry Set. If 






Yes, Branch to 0158 


0107 


+50 




0108 


STA 


If Not, Store Results 






of Add 


0109 


ADL3 


Result, Lov Byte 


OlOA 


ADH3 


Result, High Byte 


0158 


OP CODE 


New Instruction 
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The 0108 represents the value of the program counter after 
reading the offset value. The program counter automatically incre- 
ments so It can reference the next memory location on the next cycle. 
The add of the offset is a signed binary add as discussed in the arith- 
metic section. A positive branch is indicated by a in bit 7 of the 
relative value, and a minus branch is in two's complement form and is 
indicated by a 1 in bit 7. The inherent capabilities of this type of 
notation system allow branch conditionally forward 127 bytes from 
the next instruction and back 128 bytes from that instruction. All 
branches in the R6500 series are conditional relative branches 
and all have the form shown above. The advantage of relative ad- 
dressing is best shown in the following example: 

Example A. 5 : Sequencing Two Branc h Instructions 



Address 


Data 


Comments 


0100 


LDA 


Load First Value 


0101 


ADLl 




0102 


ADHl 




0103 


ADC 


Add Second Value 


OlOA 


ADL2 




0105 


ADH2 




0106 


BCS 


Test for Carry Set. If 






Yes, Branch to 0158 


0107 


+50 




0108 


BMI 


Test for Minus Number. 






If Yes, Branch to 0095 


0109 


-75 




OlOA 


STA 


If Not, Store 


OlOB 


ADL3 




OlOC 


ADH3 





In this example, the previous single-branch example was modi- 
fied to also test the resulting number to see if it is negative. In 
sequencing two-branch instructions, this loop is two bytes shorter by 
use of relative branches rather than three byte branches. 
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4.1.2 Branch Instructions 

4.1.2.1 BMI — Branch on Result Minus 

This Instruction takes the conditional branch if the N bit 
is set (1). Branch on result minus is used to determine if the previous 
result was minus or bit 7 was on (1). 

BMI does not affect any of the flags or any other part of 
the machine except the propram counter and then only if the N 
bit is set. 

The mode of addressing for BMI is Relative. 

4.1.2.2 PPL — Branch on Result Plus 

This instruction is the complementary brancti to branch on 
result minus. It is a conditional branch which takes the branch when 
the N bit is reset (0). BPL is used to test if the previous result 
bit 7 was off (0) . 

The instruction affects no flags or registers other 
than the P counter and only affects the P counter when the N bit is 
reset . 

The addressing mode is Relative. 

4.1.2.3 BCC — Branch on Carry Clear 

This instruction tests the state of the carry bit and takes 
a conditional branch if the carry bit is reset (0). 

It affects no flags or registers other than the program 
counter and then only if the C flag is reset, 

The addressing mode is Relative 

4.1.2.4 ECS — Branch on Carry Set 

This Instruction takes the conditional branch if the carry 
flag is set (1) . 

BCS docs not affect any of the flags or registers except for 
t 

the program counter and only then if the carry flag is set. 
The addressing mode is Relative. 
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4.1.2.5 6EQ — Branch on Result Zero 

This instruction could also be called "Branch on Equal." 
It takes a conditional branch whenever the Z flag is set (1), indicating 
that the previous result was equal to 0. 

BEQ does not affect any of the flags or registers other than 
the program counter and only then when the Z flag is set. 

The addressing mode is Relative. 

4.1.2.6 BNE — Branch on Result Not Zero 

This Instruction could also be called "Branch on Not Equal." 
It tests the Z flag and takes the conditional branch if the Z flag is 
reset (0), Indicating that the previous result was not zero. 

BNE does not affect any of the flags or registers other than 
the program counter and only then If the Z flag is reset. 

The addressing mode is Relative. 

4.1.2.7 BVS — Branch on Overflow Set 

This instruction tests the V flag and takes the conditional 
branch if V is set (1) 

BVS does not affect any flags or registers other than the 
program counter and only when the overflow flag is set. 

The addressing mode is Relative. 

4.1.2.8 BVC — Branch on Overflow Clear 

This instruction tests the status of the V flag and takes 
the conditional branch if the flag is reset (0). 

BVC does not affect any of the flags or registers other 
than the program counter and only when the overflow flag is reset. 

The addressing mode is Relative. 
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A. 1.3 Branch Summary 

To summarize, tlie R6500 branches have two clia rac t er is t ics ; 
each of them tests the state of a flag and then either accesses the 
next instruction in program sequence if the flag is not in the tested 
state or adds the offset value to the PC value at the OP CODE of the 
next instruction (PC + 1) to allow the program to change operations. 
This gives the programmer the full ability to make decisions. By 
writing a sequence of branch instructions, any combination of condi- 
tions of the microprocessor may be determined and new action taken 
as a result of the tests . 

There are four branch conditions in the R6500 Series micropro- 
cessors. These are branch on carry flag, branch on overflow flag, 
branch on N flag, and branch on zero flag. Each of the branches has 
a branch on flag set (1) or branch on flag clear (0). 

A.l.A Solution to Branch Out of Range 

The branch relative instruction is unlike the jump instruc- 
tion which can reach anywhere in memory , since branch relative is 
limited to +129 or -125 from the current program counter location. 
Although for many loops and many tests this is sufficient range, 
longer programs will occasionally find it necessary to condition- 
ally branch to a location that is significantly further away than 
the branch command will directly reach. This is one of the uses 
of complementary branches. If a program should find it necessary 
to branch to a location which was significantly further away than 
129, the following solution would facilitate the branch: 



t 
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Example A. 6 : Use of JMP to Branch Out of Range 



Address Data Comments 

100 LDA Load First Value 

101 ADLl 

102 ADUl 

103 ADC Add Second Value 

104 ADL2 

105 ADH2 

106 BCC Branch, If Mo Carry, 

Ahead 3 (to Point 2) 

107 +3 

108 JMP If Carry set. Jump to 

Location Specified by 
ADH4. ADL4 

109 ADL4 
lOA ADH4 

Point 2 lOB BMI Check for Minus 

IOC Offset 
lOD STA 

lOE ADL3 If not IMnus , Store 

Result 

lOF ADH3 



In this example, carry set is being checked. In order to accomplish 
this when the branch command would have to reach outside of the 128 
range, the use of a complementary branch is required. Instead of 
doing the "branch on carry set" to the location, the "branch on 
carry clear*' is utilized (a complementary instruction) which branches 
past the jump. If the complementary branch is not taken, the jump is 
the "branch on carry set" function. 

This technique of branching past a jump with the complementary 
branch is a universal solution to the branch out of range problem. 

Another solution is to find a like branch to the same location 
that is within range and, although this involves two branches to trans- 
fer control, it does save memory locations. 

By use of the relative branch fewer bytes of code are required than 
if a conditional jump had been used. However, in large programs, the 
branch out of range occurs more frequently. If the user can determine 
that a branch will be out of range by inspection, he should apply the 
jump solution at the time he is writing the code. Otherwise, the 
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assemblers will indicate an out-of-range branch which will require 
receding to use the jump solution. 



4.2 TEST INSTRUCTIONS 

Although most of the normal operations of the microprocessor involve 
setting of flags, there are specific instructions which are designed only 
to set flags for testing with the branch instruction. 

•4.2,1 CMP - Compare Memory and Accumulator 

This instruction subtracts the contents of memory from the 
contents of the accumulator. 

Its symbolic notation is A - M. 

The use of the CMP affects the following flags: Z flag is 
set on an equal comparison, reset otherwise; the N flag is set or 
reset by the result bit 7, the carry flag is set when the value in 
memory is less than or equal to the accumulator, reset when it is 
greater than the accumulator. The accumulator is not affected. 

It is a "Group One" instruction and therefore has as its 
addressing modes: Immediate; Zero Page; Zero Page, X; Absolute; 
Absolute, X; Absolute, Y; (Indirect, X); (Indirect), Y. 

The purpose of the compare instruction is to allow the user 
to compare a value in memory to the accumulator without changing 
the value of the accumulator. An example of where this becomes 
extremely important is when one is receiving command instructions 
from an external device. In this case, an input byte may have 
several values. Each value can cause the program to perform a 
different operation. The only rapid way to determine the value of 
the input data is to compare the memory with a series of constants. 
It is fairly simple to perform "compare to constant" operations. 
By use of the immediate addressing mode which will be developed 
later, the following example compares an input to three values 
and branches to different locations for each: 
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Example 4.7 : Using the CM P Instruction 



Data 

LDA 
ADL 
ADH 
CMP 

COUNT 1 
BEQ 

OFFSET 1 
CMP 

COUNT 2 
BEQ 

OFFSET 2 
CMP 

COUNT 3 
BEQ 

OFFSET 3 
Next Inst. 



Comments 

Load Value 
Address Low 
Address High 

Compare COUNT 1 to Accumulator 

If Equal, Take the Branch of OFFSET 1 

Compare COUNT 2 to Accumulator 

If Equal, Take the Branch of OFFSET 2 

Compare COUNT 3 to Accumulator 

If Equal, Take the Branch of OFFSET 3 



Otherwise, Go to Next Instruction 
Based on Default Value (COUNT A). 

This example shows how to use the default option . A value 

was compared against three values and, if none were equal, a fourth or 

default value is assumed. This is a useful technique for code 

minimization. 

The compare instruction is designed to allow a signed compari- 
son between two values, assuming one makes appropriate use of the Z and 
N and C flags. In order to give maximum flexibility to the instruc- 
tion, the instruction performs an ef feet ive . subtract between the value 
in memory and the value in the accumulator. The reason it is an ef- 
fective subtract is that subtraction permits the user to compare equal 
or less with one instruction. 

The results of a compare are: 



Accumulator < Memory 
Accumulator = Memory 
Accumulator > Memory 



N 

Either 

Reset 

Either 



Reset 
Set 
Set 



Reset 

Set 
Reset 



Unchanged 
Unchanged 
Unchanged 



So, to check if the accumulator is less than memory, the com- 
pare is followed by a BCC; to check if equal to it is followed by a BEQ; 
and to check if greater it is followed by a BEQ followed by a BCS . 
Greater than or equal to is checked by BCS. 
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4.2.2 Bit Testing 

The comparison instruction is designed for cases when byte or 
multiple bytes of values are being compared; however, in the analysis 
of logic functions, it is very often necessary to determine the con- 
dition of an individual bit. One of the ways to accomplish this is 
with the use of the AMD instruction as previously discussed. In other 
words, the user can load a value into the accumulator and AND it with 
a field that contains a one bit only in the corresponding bit pos- 
tion to the bit under test. By using a Brancli on Zero Flag after 
the AND, the status of the bit in memory is testable by tliis tech- 
nique. However, the use of this technique involves destroying the 
accumulator value with the AND instruction. Therefore, searching a 
table looking for a single bit in a given position would necessitate 
the reloading of the test value (mask) after each AND instruction. 
In order to allow memory sampling without disturbing tiie accumulator, 
the BIT instruction is used. 

4.2.2.1 BIT — Test Bits in Memo ry wit h Accumulator 

This instruction performs an AND between a memory location 

and the accumulator but does not store t}ie result of the AND into 

the accumulator. 

The symbolic notation is M /V A. 

The bit Instruction affects the N flag with N being set to 
the value of bit 7 of the memory being tested, the V flag with V 
being set equal to bit 6 of the memory being tested and Z being set 
by the result of the AND operation between the accumulator and the 
memory if the result is Zero, Z is reset otherwise. It does not 
affect the accumulator . 

The addressing modes are Zero Page and Absolute. 

The BIT instruction, like the compare test, permits the examination of 
an individual bit without disturbing the value in the accumulator and is 
illustrated by the following example: 
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I : x.imp]e ^ .8 : Samp Ic Program U5lns__tJ ic' BIT Tcb L 
Data Comments 

LDA Load MASK into Accumulator 

MASK 

BIT Test First Memory Value for Mask Bit 

AO LI 

ADHl 

BNE Branch if Set 

+50 

BIT Test Second Memory Value for Mask Bit 

A1)L2 

AI)U2 

BNE Branch if Set 

-75 

etc. 

The value "MASK" loaded into the accumulator in this example 
is actually a descriptive title since this byte is 8 hits only one 
of which is a 1. Using tliis byte in the AiNI) operation inlierent in the 
BIT test will effectively mask out all bits in the memory location under 
test except tliat bit position corresponding to the 1 residing in tlie 
accumulator. In Example A. 8. the MASK byte is AND'ed to the data 
found in location ADHl, AJ)L1 and if lite b^ t under lest is a 1, the 
branch will be taken; if not a J, tlie second memory location will be 
tested witli the same mask, etc. 

In addition to the nondestructive feature of the bit which 
aJlows us to isolate an individual hit by use of ttie branch equal or 
brancli not equal test, two modifications to the PDP-11 version of that 
instruction have be<-n made in the VJ>'y')'' series n i r r .^m ocessors . Thesr 
modif icationri are made to permit a lest of bit 7 and hit of the field 
examined with the BIT test. This fealnre is particularly useful in serving 
polled interrupts, and especiallv in dealing wilh the ^520 Peripheral 
Interface Device. This device has an inierrupt sense bit in bit .nid bit? 
of Ihe slatus words. It is a standard of the Mf>Hf)0 bus lh:M whenever 
possible, bit 7 reflects the interrupt slatus of an I/O device. This 
means tliat under normal circumstances, an analysis of tlie N flag 
after a load or BIT instruction should indicate tiic status of the 
bit 7 on tlte 1/0 device being sampled. To facilitate tliis test using 
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the BIT instruction, bit 7 from the memory being tested is set 
into the N flag irrespective of the value in the accumulator. 
This is different from the BIT instruction in the M6800 which re- 
quires that bit 7 also be set in the accumulator to set N. The 
advantage to the R6520 user is that if he decides to test bit 7 
in the memory, it is done directly by sampling the N bit with a 
Bit followed by branch minus or branch plus instruction. This 
means that with the R6520. I/O sampling can be accomplished at 
any time during the operation of instructions irrespective of the 
value preloaded in the accumulator. 

Another feature of the BIT test is the setting of bit 6 into 
Che V flag. As indicated previously, the V flag is normally reserved 
for overflow into the sign position during an add and subtract in- 
struction. In other words, the V flag is not disturbed by normal 
instructions. When the BIT instruction is used, it is assumed that 
the user is trying to examine the memory that he is testing with the 
BIT instruction. In order to receive maximum value from a BIT in- 
struction, bit 6 from the memory being tested is set into the V flag. 
In the case of a normal memory operation, this just means that the 
user should organize his memory such that both of his flags to be 
tested are in either bit 6 or bit 7, in which case an appropriate 
mask does not have to be loaded into the accumulator prior to imple- 
menting the BIT instruction. In the case of the R6520, the BIT 
instruction can be used for sampling interirupts, irrespective of the 
mask. This allows the programmer to totally interrogate both bit 6 and 
bit 7 of the R6520 without disturbing the accumulator. In the case 
of the concurrent interrupts, i.e., bit 6 and bit 7 both on, the fact 
that the V flag is automatically set by the BIT instruction allows 
the user to postpone testing for the "6th bit on" until after he has 
totally handled the interrupt "for bit 7 on" unless he performs an 
arithmetic operation subsequent to the BIT operation. 
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CHAPTER 5 



NON-INDEXING ADDRESSING TECHNIQUES 



5.0 ADDRESSING TECHNIQUES 

The addressing modes of the R6500 Microcomputer System's mic ronrocessor 
(CPU) family can be grouped Into two major categories: indexed and non- 
indexed addressing. This section deals with th" non-indexed mode of address- 
ing. Before detailing the various modes available to the user, several con- 
cepts win be reviewed. The first of these is the concept of memory field. 
Pddress bus and data bus. Then a brirf infroduction to two non-indexed add- 
ressing modes and timing will be made with the intent of pror^aring the read- 
er for a discussion of pro^^ram sequence and the internal activity of the 
microprocessor during execution of an instruction. This will be followed by 
a review of how one treats memory and the assorted allocation of memory space 
to the elements of RAIl, ROM and I/O. 

SubsGoucnt to reading this section the user should hav- an understand- 
ing of the following fundamentals: 

• Memory Field 

• Address Bus 

• Data Bus 

• Cycle Timing 

• Program Sequence 

• Pipelining 

With these tools in hand, the reader will be better prepared to readily 
comprehend the detailed definitions of the non-indexed addressing modes. 

As discussed in Sect^'on l.l, the R6500 System's microprocessor family 
i is organized around a 16-bit address function. All locations are accessed 
' by a 16-bit word, even though in the case of the R6503 thru 6507 and 6513 
thru 6515 only 11 or 12 bits are actually utilized. 
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SixLi'cn bits o\ address allow access Lo 6'>/)^(. nH-mory 1 (u ,i t i on , i-;u li 
ur wliich, in thv R6S0O scric-s, tonsisls of 8 bits of d.-.t.i, ri^',uir ^.1 
displays ilK- toLal mfmory iield and i ncorpor j Lcs Ihi- rnnrc\^t ol addicss bus 
and data bus. Tht- numory address can be regarded as 256 pa^es (eaLli f^aRe 
defined by tlie high- order byte) of 236 memory lot a I ions (hytes) per page. 
It will be seen in the detailed distussion ot addressing tiiat tbe lowest- 
order page, p.7gr zero» lias spciMal significance in ttie ni i n i m i za t. i en ol i>ru- 
gram code and exeeution time. 

Much of the uniqueness of tlie R6500 produrl family has to do with 
how the 16-bit address is created. The simplest way to create a 16-bit ad- 
dress is for the programmer to indicate to the mi < roprocesscu' tlu- 16 bits 
necessary to access a particular opei and on win rb t lie m i e r op roc ess i r is ex- 
pected to operate. An instruction consists of 1, , or 3 hytes. U always 
takes 1 byte to specify the operation which is to he performed ((.>!' t:()l)l ) . 
This 01' COIJK is then followed by 0, 1, or : bytts nl address depending on 
the specific operation involved. In tlie case of Ibc simple instructions 
such as transfer accumulator to X, operations are prrt<u-i!Kd inleina)]\ and, 
therefore, no additional! Ijytes are necessary. This instruction mode is 
known as "implied" in the sense that the instinct ion contaitv. b>'th the OV 
CODL and the source and destination for the >.[uM,aion. Th i is t ht simplest 
form ol addressing and applies t 'j only a limiie.l ruinilu-r of t b,. i r.;- 1 r uc t ixjiis 
available in the Rb'A)0 family. Anoilui 'or-i of add ress i n,' , . - i^s> > ^. 1 ad- 
dressing, is the case when t\i^' programmer spi^:'i!i.-; dirc 'lv tr ; m( imcio- 

Lhe microprocessor to ust in U^tibinw;, I be- 



processor the address lie want 
memory value on which tlie operation will occur 
by Clie example below. 

E xample 5. 1: UsJ_aiL.^J^i^AllyJ^.^...A'y ^.'^ 



Clock Cyc le 



Address Bus 



'Ibis form 



Data Bu^. 



i 1 1 us 1 1 a ted 



1 0100 LUA, Absolute 

2 0101 /U)L 

3 0102 ADH 
AUH, ADL Data 

In this example, memory location 0100 contains the OP COUK "LDA Abso- 
lute." The next location, 0101. contains ADh which will be defined as the 



"low-order byte of the address,*' hence address low (ADL). Location 0102 
contains ADH — the "high-order byte of the address," hence address high 
(ADH). At the next clock cycle, the 16 bits composed of ADH and ADL are nut 
on the address bus with the location defined by ADH, ADL containing the data 
to be loaded into the accumulator. The effective address of the data is best 
described in Figure 5.1, where the 16-bit address (ABOO through AB15) is com- 
posed of ADH and ADL. 

This is the normal form for an absolute memory address. The first byte 
of the instruction which is picked up by the program counter is the operation 
code. This is interpreted by the microprocessor as "Load A - Absolute." At 
the same time that this Load A is being interpreted by the microprocessor, the 
microprocessor accesses the next memory location by putting the program coun- 
ter content, which was incremented as the OP CODE was fetched, on the addr-ss 
bus . 

5. 1 CONCEPTS OF PIPELINING AND PROGRAM SEQUENCE 

The overlap of fetching the next memory location while interpreting the 
currert data from memory minimizes the op-rnMon time of a normal 2- or 3-byte 
instruction and is referred to as 'nipe 1 i^S • ' ^^^^"^ feature that 

allows a ?-byte instruction to take only 2 clock times and a 3-byte instruc- 
tion to be interpreted in 3 clock cycles. 

In the R6500 series microprocessors, a clock cycle is defined as one 
complete operation of each of the two phase clocks. Figure 5.? is a sketch 
of the address and data bus tiding as \t relates to the system clocks. 

The major point to be noted is that every clock cycle in the micro- 
processor is a memory cycle in which memory is either read or written. Simul- 
taneously with the read or write of memory, an internal operation of the 
B: microprocessor is also occurring. 




"_n n 

•2 n n r 



ADDRESS LINE 
DATA LINE 



Example of Timing -- A R6500 Microcomputer System Microprocessor 
FIGURE 5 J 



The following example will let 
Example 5.2 : Demonstration of 



us analyze this effect: 
"Pipelining" Effect 



Clock 

Cycles External Operation 
1 Fetch OP CODE 



Fetch first-address 
half from memory 



Fetch second ad- 
dress half from 
memory 

Fetch operand from 
memory 

Fetch next OP CODE 
from memory 



Fetch address from 
memory 



Address Data Internal Operation 



100 



101 



102 



ADH. 
ADL 

103 



104 



ADC Increment P-counter 
to 101 

ADL Increment P-counter 
to 102, Interpret 
ADC instruction 

ADH Increment P-counter 
to 103; Hold ADL 



Data Load Data 



STA Increment P-counter 
to 104 , Perform ADC 
operation: 
A + M + C 

ADL Increment P-counter 
to 105, Result of 
Add -> accumulator. 
Interpret STA Instruc- 
tion 



The above example shows the operation of an ADC, add with carry in- 
struction, using absolute addressing. In the first cycle, the OP CODE is 
fetched from memory addressed by the P-counter. To implement the 



look-ahead or pipeline in cycle two, the fetch of ADL address low is done | 
simultaneously with the interpretation of the AUG absolute instruction. 
By the end of cycle 2, the microprocessor knows that it should access the I 
next memory location for the address high as a result of interpretation ofj 
the absolute addressing mode. 

The address low (ADL) is stored in the ALU while the address high (Al 
is being fetched in cycle 3. 

On the fourth cycle, no internal operation is necessary while the 
microprocessor is putting the calculated value onto the address bus. Howj 
ever, during this cycle, the operand is loaded into the microprocessor. 
The four cycles have all been involved with memory access for the 
absolute instruction. The first to fetch the instruction, tlie second to 
fetch the address low, the third to fetch the address high, and the fourthi 
to use the^ calculated address to fetch the operand. Because that compleU 
the memory operations for this instruction, during the fifth cycle the 
microprocessor starts to fetch the next instruction from memory while it 
is completing the add operation from the first instruction. During the 
sixth cycle, the microprocessor is interpreting the new instruction fetch( 
during cycle 5 while transferring the result of the add operation to the 
accumulator. This means that even though it really takes six cycles for 
the nicroprocessor to do the ADC instruction, the programmer only need 
corccrn himself with the first four cycles, as ttie next two are overlnppe(l| 
as shown. 

AIJ instructions ta'/e at least two cycles; one to fetch the OP CODE 
and one to interpret the OP CODE and, with few exceptions, the number of 
cycles that an instruction takes is equal to the number of times that 
memory must be addressed. 

The details of h{)w each addressing', mode is overlapped .'*ro described! 
in the individual sections, and for sporifir details of earli cycle in varH 
ous operations the user is rrfprrod to the H.-irdwarr MaiMial, Appendix A. 



5.2 MEMORY UTILIZATION 

As indicated, the 16-bit address allows the user to access greater 
than 65,000 separate locations. Most of the locations which will be ac- 
cessed in the course of a control problem will be in program or P-counter 
referenced locations. A typical program will probably range from 1000 to 
8000 bytes and will normally be implemented in fixed ROM or non-volatile 
alterable ROM. 

A second type of memory will be the read-write memory in which the 
user keeps data such as working values, input and output data. Depending 
on the type of problem being addressed, this RAM usually ranges from 32 
bytes to 8000 bytes, although most applications will be under 2000 bytes 
of RAM. 

It would seem there is significant address space not used in most 
applications. To get the maximum benefit of the addressing space, two 
concepts are implemented in the R6500 series. These are the use of data 
addressing as I/O control, and distributed address connections for minimum 
control lines. The latter concept utilizes the address bus, which is 
basic to and therefore pervasive in any microcomputer system, as a con- 
trolling network whenever possible. An example of this is the use of the 
address bus in selecting devices to interface with the microprocessor. 

5.2.1 I/O Control 

The advantages of accessing I/O as memory are 1) the use of 
distributed address space allows for simple I/O control lines and 2) 
all of the power of the instructions is applied to I/O operations. 
This has the advantage of minimizing I/O hardware and allows the pro- 
grammer to be innovative in the application of I/O devices in solving 
his problem. 

All R650O product family I/O devices contain 8-bit registers 
which are addressed by the microprocessor as though they were a mem- 
ory byte. In the simplest case, the 8-bit register being read con- 
|if i . tains a I's and O's pattern which corresponds to the TTL voltage level 

applied to eight input pins to the I/O device. 
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If the register were a flip-flop register driving eight output 
pins with TTL levels, the storing of eight bits of data with a STA 
instruction into that I/O register would, in effect, be programming 
the flip-flop to a specific desired state. Thus, one can use the in- 
structions with the I/O just as any other memory location. 

5.2.2 Memory Allocation 

Figure 5.1 displays the relationship between memory, address 
bus and data bus while referencing the address values in hexadecimal 
notation. The previous section has dealt with utilization of memory 
address space for not only ROM and RAM but for I/O as well. At this 
time, the concept of allocation of the memory field of Figure 5.1 to 
the elements of ROM, RAM and I/O will be considered. The allocation 
below satisfies most applications requirements and represents only a 
suggested allocation for minimization of programming code and speed. 

Hexadecimal Address Suggested Allocation of Memory 

0000 - 3FFF RAM 
AOOO - 7FFF I/O 
8000 - FFFF ROM 

It should be noted that the three memory block address 
definitions which, while not mandatory or required for proper system 
operation, do represent a logical assignment of space. The choice 
for this particular allocation will be presented in Section 9.12. 
In the meantime, the reader should retain the concept of the various 
memory blocks allocated to RAM, I/O and ROM as they are useful in the j 
following discussion. 

5 J IMPUliO ADDRi:SStN(J 

Instructions which use implied addressing are single-byte instructions, j 
The byte contains the OP CODE which stipulates an operation internal 
to the microprocessor. Instructions utilizing this type of addressing i"" 
elude operations which clear and set bits in the P (Processor Status) reg- 
ister, incrementing and decrementing internal registers and transferring 



contents of one internal register to another internal register. Operations 
of this form take two clock cycles to execute. The first cycle is the OP 
CODE fetch and. durinp, this fetch, the program counter increments. 

In the second cycle, the Incremented P-counter is now the address of 
the next byte of the instruction. However, since the OP CODE totally de- 
fines the operation, the second Memory fetch is worthless and any F-counter 
increment in the second cycle Is suppressed. During the second cycle, the 
OP CODE is decoded with recognition of its single-byte operation. 

In the third cycle, the microprocessor repeats the same address to 
fetch the next OP CODE. This is the second time the memory address is 
fetched; once as the second byte of the first instruction and second, as 
the correct OP CODE address for the next instruction. 

A symbolic representation of a 2-cycle instruction is given below. 
"PC" means "Program Counter." 



Example 5.3 : Illustration of Implied Addressing 



Clock 
Cycle 

1 
2 



Address Bus Program Counter Data Bus 



PC 

PC + 1 



PC + 1 



PC + 1 
PC + 1 



PC + 2 



OP CODE 
New 

OP CODE 



New 

OP CODE 



Comments 

Fetch OP CODE 

Ignore New 
OP CODE; 
Decode Old 
OP CODE 

Fetch New 
OP CODE; 
Execute Old 
OP CODE 



■i^. Instructions which use implied addressing and require only 2 cycles 

include CLC. CLD. CLI, CLV, DEX. DEY, INX, INY, NOP, SEC. BED, SEI. 
TAX, TAY, TSX. TXA, TXS. and TYA. 

Instructions utilizing implied addressing and which require more than 
I 2 cycles are stack operations which Include BRK, PHA, PHP, PLA. PLP, RTI, and 
RTS. 



5-8 



5-9 



5.4 IMMEDIATE ADDRESSING 

Instructions which use immediate addressing are 2-byte Instructions. 

The first byte contains the OP CODE specifying the operation and 
address mode. The second byte contains a constant value defined by the 
programmer. It is often necessary to compare, load and/or test against 
certain known" values . Rather than requiring the user to define and load 
constants into some auxiliary RAM, the microprocessor allows the user to 
specify constant values by the immediate addressing mode. 

Example 5.4 : Illustration of Immediate Addressing 

Cycle Address Bus Program Counter Data Bus Comments 

^ PC PC + 1 OP CODE Fetch OP CODE 

, pr + 1 PC + 2 Data Fetch Data, 

^ Decode OP CODE 

3 PC + 2 PC + 3 New Fetch New 

OP CODE OP CODE. 

Execute Old 
OP CODE 

Immediate addressing is the simplest form of constant manipulation 
available to the programmer. It requires a minimum execution time in the 
sense that one cycle is used in loading the OP CODE and as this CODE is be- 
ing interpreted, the constant is being fetched. 

Instructions utilizing immediate addressing are ADC, AND. CMP, CPX. 
CPY, EOR, LDA. LDX, LDY , ORA, and SBC, 

5.5 ABSOLUTE ADDRESSING 

Instructions which use absolute addressing are 3-byte instructions. 

The first byte contains the OP CODE for specifying the operation and 
address mode. The second byte contains the low-order byte of the effective 
address (that address which contains the data), while the third byte con- 
tains the high-order byte of the effective address. Thus, the programmer 
specifies the full 16-bit address and, since any memory location can be 
specified, this is considered the most normal mode for addressing. Other 
modes may be considered special subsets of this 16-bit addressing mode. 
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Example 


5.5: Illustration of Absolute Addr 


easing 




Clock 
Cycle 


Address Bus 


Prof^ram Counter 


Data Bus 


Comments 


1 


PC 


PC + 1 


OP CODE 


Fetch OP CODE 


2 


PC + 1 


PC + 2 


ADL 


Fetch ADL, 
Decode OP CODE 


3 


PC + 2 


PC + 3 


ADH 


Fetch ADH, 
Hold ADL 


4 


ADH, ADL 


PC + 3 


Data 


Fetch Data 


5 


PC + 3 


PC + 4 


New 

OP CODE 


Fetch New 
OP CODE, 
Execute Old 
OP CODE 



The basic operation of the microprocessor in an Absolute address mode 
Is to read the OP CODE in the first cycle while finishing the previous 
operation. In the second cycle, the microprocessor automatically reads 
the first byte after the OP CODE (in this case the address low) while 
Interpreting the operation code. At the end of this cycle, the microproces- 
sor knows that it needs a second byte for program sequence; therefore, one 
more byte will be accessed using the program counter while temporarily 
storing the address low. This occurs during the third cycle. In the 
fourth cycle, the operation is one of taking the address low and address 
high that were read during cycles 2 and 3 to address the operand. For ex- 
ample, in load A, the effective address is used to fetch from memory the 
data which is going to be loaded in the accumulator. In the case of stor- 
ing, data is transferred from the accumulator to the addressed memory. 

As was illustrated in the review of pipelining, depending on the in- 
''struction, it is possible for the microprocessor to start the next instruc- 
* tion fetch cycle after the effective address operation and independently of 
■how many more internal cycles it may take to complete the OP CODE. The 
t only exception to this is the case of "Jump J^bsolute" in which the address 
if low and address high that are fetched in cycle 2 and cycle 3 are used as 

the 16-bit address for the next OP CODE. The jump absolute therefore only 
I requires three cycles. In all other cases, absolute addressing takes four 
cycles, three to fetch the full instruction including the effective address, 
the fourth to perform the memory transfer called for in the instruction. 
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Absolute Addressing always takes three bytes of program memory; one 
for the OP CODE, one for the address low, one for the address high. 

Instructions which have absolute addressing capability include ADC» 
AND. ASL, BIT, CMP, CPX. CPY . DEC, EOR, INC. JMP . JSR. LDA . LDX. LDY , LSR, 
ORA. ROL. ROR, SBC. STA, SIX. and STY. 

5.6 Z£RO PAGE ADDRESSING 

Instructions which use zero page addressing are 2-byte Instructions. 
The first byte contains the OP CODE, while the second byte contains the 
effective address in page zero of memory. 

As seen in absolute addressing, the ability to address anywhere in the 
65K memory space costs three bytes of program space, plus a minimum of four 
cycles to perform address operations. In order to allow the user to shortea 
both memory space and execution time, particularly when dealing with 
working registers and intermediate values, the R6500 System's microprocessor 
family has a special addressing mode that automatically assumes the effect- 
ive address high (ADH) to be that of the lowest page of memory. In order to 
understand the page concept one should think of each of the various memory 
addresses as comprising a consecutive block of 256 locations which have an. 
independent high-order address associated with that block. Each block is 
called a page. Other than for zero page and for calculating indexed ad- 
dresses which will be covered in the following sections, the microprocessor 
pays little attention to the page concept. 

The microprocessor assumes that the high-order byte of the effective 
address, for instructions which indicate the zero page addressing option, j 
is all O's (ADH - 00. hexadecimal). This allows the following sequence 
to occur: 
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Example 5.6: Illustration of Zero Page Addressing 



Clock 
Cycle 

1 
2 

3 
4 



Address Bus Program Counter Data Bus 



PC 

PC + 1 

DO, ADL 
PC + 2 



PC + 1 
PC + 2 

PC + 2 
PC + 3 



OP CODE 
ADL 

Data 
New 

OP CODE 



Comments 

Fetch OP CODE 

Fetch ADL, De- 
code OP CODE 

Fetch Data 

Fetch New 
OP CODE. Exe- 
cute Old 
OP CODE 



On the first cycle, the microprocessor puts out the program counter, 
reads the OP CODE and increments the program counter. On the second cycle, 
the microprocessor puts out the program counter, reads the effective ad- 
dress low, interprets the OP CODE and increments the program counter. So 
far, the operations are identical to those described in the absolute ad- 
dressing mode. However, by the end of the second cycle, the microprocessor 
has decoded the fact that this is a zero page operation and on the next 
cycle, it outputs address 00, as the effective address high, along with 
the address low that It just fetched, and then either reads or writes mem- 
ory at that location, depending on the OP CODE. 

The advantage of zero page addressing is that it takes only two bytes, 
one for the OP CODE and one for the effective address low; and only three 
I cycles, one to fetch the OP CODE, one to fetch the address low, and one to 
p fetch the data, as opposed to absolute addressing which takes three bytes 
I and four cycles. 

In order to make most effective utilization of this concept, the user 
•should organize his memory so that he is keeping his most frequently 
^'accessed RAM values in the memory locations between and 255. If one 
organizes the zero page of memory properly, including moving data into 
these locations for longer loops, significant shortening of program code 
and execution time can be obtained. 

The concept of zero page is so important that the R65O0 
assemblers have error notations which indicate when inproper use of this 
space is made . If one 's memory is organized accord ing to the guidelines 
shown in Section 5.2.2, one normally will find working storage located in 
values from to 255, This is an important aspect of the discipline known 
as "memory management," 
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Once Che pattern of codin.q for the P.650X or R&51X, which considers 
working storage or registers in the zero page, becomes a habit, one finds 
that in most control applications, all of the working registers will take 
advantage of this programming and the associated time reduction without any 
special effort on the user's part. 

Instructions which allow zero page addressing include ADC, AND, ASL, 
BIT, CMP, CPX, CPY, DEC, EOR, INC, LDA, LDX, LOY , LSR, ORA, ROL, ROR, SBC. 
STA, SIX, and STY. 



5.7 RELATIVE ADDRESSiNG 

As discussed in Section 4.1, all of the branch operations in the micro- 
processor use the concept of relative addressing. In example 5.7, it is 
seen that for the case of the straightforward branch in which the branch 
is not taken, on the first program count cycle, the microprocessor puts 
out the program counter as an address, fetches the OP CODE and finishes the 
previous operation. During the second cycle, the program counter is put 
on the address bus, picking up the relative offset. Internally, the micro- 
processor is decoding the OP CODE to determine tliat it is a branch instruc- 
tion. 

Example 5.7 : Illustration of Relative Addressing: Bran ch Not Taken 



Cycle 
1 



Address Bus 
0100 

0101 

0102 



Data Bus 
OP CODE 

Offset 



Next 
OP CODE 



External 
Operation 

Fetch 
OP CODE 

Fetch 
Offset 

Fetch Next 
OP CODE 



Internal 
Operat ion 

Finish Previous Oper- 
ation , Increment Pro- 
gram Counter to 101 

Interpret Instruc- 
tion, Increment Pro- 
gram Counter to 102 

Check Flags, Increment 
Program Counter to OlO] 



This is only the second cycle of an internal operation; therefore, the 
microprocessor may be storing a computed value from the previous instruc- 
tion at the same time it is finishing interpreting the present instruction.. 
It is while doing the store operation that the flags in the machine get 
physically set; therefore, the microprocessor allows the program counter 
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to go one more cycle to allow itself time to determine the value of the 
flags. For example, if the previous instruction is ADC, the flags will 
not get set until the cycle in which the offset value is fetched. 

During the third cycle, the microprocessor puts the incremented PC 
onto the address bus, fetches the next OP CODE and checks the flag in 
order to decide whether or not the program counter value that is going out 
is correct and that the branch is not going to be taken. Therefore, an 
additional type of pipeline, in this case fetching the next OP CODE in a 
branch sequence, accomplishes the implementation of a branch relative with 
no branch being taken. This requires two cycles. One cycle fe':ches the 
branch OP CODE and one cycle fetches the next operation, the relative off- 
set. The second fntch is ei'fectively ignored by virtue of the fact that the 
branch is not taken, so the program counter location has already been incre- 
mented and the next OP CODE has already been fetched by the microprocessor. 

If in the above example it is assumed that the flag is set such that 
the branch is taken and the relative offset is +50, the microprocessor 
takes a third cycle to perform the branch operation. 

Example 5.8: Illustration of Relative Address ing; P>ranch Positive 
Taken , No Cross inp of Pape Boundar ies 



Cycle 
1 



Address Bus 



0100 



Data Bus 



OP CODE 



0101 



0102 



0152 



+50 



Next 
OP CODE 



Next 
OP CODE 



External Internal 
Operation Operation 

Fetch Finish Previous Oper- 

OP CODE ation. Increment Pro- 

gram Counter to 101 

Fetch Interpret Instruction, 

Offset Increment Program 

Counter to 102 

Fetch Next Check Flags, Add Rela- 
OP CODE tive to PCL, Increment 

Program Counter to 103 

Fetch Next Transfer Results to 
OP CODE PCL, Increment Program 

Counter to 153 



In Example 5.8, on the first cycle, a branch OP CODE is fetched while 
the previous operation is finished. On the second cycle, the offset is 
fetched while the branch instruction is being interpreted. On the third 
cycle , the mlc roprocessor uses the adder to add the program count low to 
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the offset and also checks the flags. Because the program count for the 
next OP CODE in program sequence is already in the program counter and is 
being incremented, the microprocessor can allow the incrementation process 
to continue. If the value for the next instruction is indicated because 
the flag is not set; then the microprocessor loads the next OP CODE and 
the add of the .program counter low to the offset value, is ignored as it 
was in the previous example. 

If during the third cycle the flag is found to be the correct value 
for a branch, the OP CODE that has been fetched during this cycle is 
ignored. The microprocessor then updates the program counter with the 
results from the add operation, puts that value out on the address bus 
which fetches a new OP CODE. 

This gives the effect of a 3-cycle branch. Thus it can be seen that 
in a case where the branch is not taken, the microprocessor has an effec- 
tive 2-cycle branch, i.e., two memory references. In the case when the 
branch is taken, the branch takes three cycles as long as the relative value 
does not force an update to the pro-ram counter hirh. In other words, 
three cycles are required if the pa-e boundary Is not crossed (recall the 
discussion of the "page" concept in Section 5.0). If in the above example 
the branch was back from address 0102 fifty locations, as opposed to- +50 
locations, the following result would occur: 

Example 5.9 : 



Illustration of Relative Addressing: 
Taken, Crossinp of Page Boundary 



Cycle 
1 



Address Bus 
0100 

0101 

0102 

01B2 

00B2 



Data Bus 



OP CODE 



-50 



Next 
OP CODE 



Discarded 
Data 



Next 
OP CODE 



Branch Negative 

Internal 
Operations 

Finish Pr,evious 
Instruction 

Interpret Instruc- 
tion 

Check Flags 
Add Relative to 
PCL 

Fetch Dis- Store Adder In PCL 
carded Data and Subtract 1 
from PCH 



External 
Operations 

Fetch 
OP CODE 

Fetch 
Offset 

Fetch Next 
OP CODE 



Fetch Next 
OP CODE 



Put Out New PCH 
and Increment PC 
to 00B3 
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In this example, the adder Is used to perform the arithmetic opera- 
tion, and the adder can do only the eight bits of addition at a time. The 
minus branch crosses back over the page boundary, therefore an intermediate 
result is developed of 01B2 which has no Intrinsic value because of the 
borrow which now has to be reflected into the program counter high. Since 
this example displays both a negative offset and the crossing of a page 
boundary, additional explanation is in order. 

The value to which the offset will be added is 0102 (hexadecimal). 
The offset itself is -50 (hexadecimal). 

Subtract low-order byte: 
02^g^ - 0000 0010 

^°HEX " 

Take two's complement of 50: 

50 - 1010 1111 

Add 1 1 

-50 - 1011 0000 

Add 02 0000 0010 
-50 1011 0000 
Carry - foj 1011 0010 

B 2 

Up to this point, the PCH has not been affected; therefore the value 
on the address bus is 01B2. 

The Carry - 0, indicating a borrow. 

Subtract high-order byte: 
O^uov " 0000 0001 
OO^^v - 0000 0000 

Take two*s complement of 00: 



°Vx - ^^^^ 

Add Carry 

-00._„ = 1111 1111 



Add 01 0000 0001 

-00 1111 1111 

Carry = fV 0000 0000 





The presence of the Carry indicates no borrow, hence a 
positive result. 
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At this time, after the arithmetic operation on both bytes of the P.C., 
the address bus will be: 00B2. 

The microprocessor does put out on the address line the intermediate 
results (01B2). thereby reading a location within the page it was currently 
working in. the value of which is ignored. It then subtracts 1. or if this 
was a branch forward to the next page, the microprocessor would add 1 to 
program counter high in this fourth cycle. In the fifth cycle, the micro- 
processor will recognize that it has the correct new program counter high 
and program counter low and is able to start a new Instruction operation, 
thereby giving an effective length to the branch operation when a page 
crossing is encountered of four cycles. 

We can see that it is possible to control the execution time of a 
branch. This is important for counting or estimating execution times of 
operations. For counting purposes, the following applies: 

If a branch is normally not taken, assume two cycles for the branch. 

If the branch is normally taken but it is not across the page boundary, 
assume three cycles for the branch. 

If the branch is over a page boundary, then assume four cycles for the 
branch . 

In loops which are repeated many times, one can assume some type of 
statistical factor between 3 and 2. or A and 2, depending on the proba- 
bility cf taking the branch versus not taking it. 

It should be re-emphasized that other than for timing purposes, page 
boundary crossings can be ignored by the programmer. 

To summarize, the relative addressing always takes two bytes, one for 
the OP CODE and one for the offset. 
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The execution time is as follows: 

Branch with Not Taking the Branch — 2 cycles 

Branch When the Branch Is Taken But _ ^ cycles 
No Page Crossing 

Branch When the Branch Is Taken with ^ cycles 

a Page Crossing 

Only branch instructions have relative addressing. The branch instru 
tlons are: BCC. BEQ, BMI, BNE, BPL, BCS. BVC, BVS. For a more detailed 
explanation of relative offset calculations the reader is referred to 
Appendix H. 
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CHAPTER 6 

INDEX REGISTERS AND INDEX ADDRESSING CONCEPTS 



6.Q GENERAL CONCEPT OF INDEXING 

In previous sections techniques for using the program counter to 
address memory locations after the operation code to develop the address 
for a particular operation have been discussed. Other than cases when 
the programmer directly changes the program memory, it can be considered 
t+iat the addressing modes discussed up until now are fixed or direct 
addresses and each has the relative merits discussed under each individual 
section. However, a more powerful concept of addressing is that of 
computed addressing. There are basically two types of computed address- 
ing; indexed addressing and indirect addressing. 

Indexed addressing uses an address which is computed by means of 
modifying the address data accessed by the program counter with an 
Internal register called an index register. 

Indirect addressing uses a computed and stored address which is 
accessed by an indirect pointer in the programming sequence. 

In the R6500 product family, both of these modes are used and 
corabinatlons of them are available. 

Before undertaking the more difficult concepts of indirect address- 
ing the concept of indexed addressing will be developed. 



In order to move five bytes of memory from a starting address of 
FIELD 1 to another set of addresses, starting with FIELD 2, the following 
program could be 'written: 

Example 6.1 : Moving Five Bytes of Data With Straight Line Code 

LABEL INSTRUCTION 

START LDA 
STA 
LDA 
STA 
LDA 
STA 
LDA 
STA 
LDA 
STA 

In this example, data are fetched from the first memory location in 
FIELD 1, as addressed by the next one or two bytes in program memory, 
stored temporarily in A and then written Into the first memory location 
in FIELD 2, also addressed by the next one or two bytes in program memory. 
This sequence is repeated, with only the memory addresses changing, until 
all the data have been transferred. This type of programming is called 
"straight line" programming becasue each repetitive operation is a sepa- 
rate group of instructions listed in sequence or straight line form in 
program memory. This is necessary even though the instruction OP CODES 
are identical for each memory transfer operation because the specific 
memory addresses are different and require a different code to be writ- 
ten into the program memory for each transfer. 

It takes a total of 10 instructions to accomplish the move when it 
is implemented this way. It should be noted that it is not indicated 
whether or not FIELD 1 and FIELD 2 are Zero Page addresses or Absolute 
addresses . 

If they were Zero Page addresses, the total number of bytes con- 
sumed in solving the problem would be two bytes for each instruction, 
thereby requiring 20 bytes of memory; if both FIELD 1 and FIELD 2 
were Absolute memory locations., each instruction would take three bytes 
and this program would require 30 bytes of program storage. 



OPERAND 

FIELD 1 
FIELD 2 
FIELD 1 
FIELD 2 
FIELD 1 
FIELD 2 
FIELD 1 
FIELD 2 
FIELD 1 
FIELD 2 



> 



COMMENTS 
Move First Value 



Move Second Value 



Move Third Value 



Move Fourth Value 



Move Fifth Value 
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The Zero Page program would execute in three cycles per in- 
struction or a total of 30 cycles, and the Absolute location version would 
execute in four cycles per instruction or a total of AO cycles. 

A new concept has been introduced in this example, that of symbolic 
notation rather than actual locations for the instructions. 

The form in which this short program is written uses symbolic 
addressing in which the address of the beginning of the program has the 
name, "START". Symbolic representations of addresses such as "START" are 
referred to as labels. The addresses in the two address fields used in 
this example have also been given names: The first address of the 
first field is called FIELD 1; and the first address of the second field is 
called FIELD 2. Each additional address in the fields has been given 
a number which is referenced to the first number; for example, the address 
of the third byte in the first field is FIELD 1+2. All of these concejits 
are implemented to simplify the ease of writing a program because the user 
does not have to worry about the locations of FIELD 1 and FIELD 2 until 
after analyzing the memory needs of the whole program. Symbolic notation 
also results in a more readable program. 

Translation from symbolic form instructions and addresses into 
actual numerical OP CODES and addresses is accomplished by a program 
called a symbolic assembler. Several different versions of symbolic 
assemblers are available for the R6500 product family. Symbolic nota- 
tion will be employed throughout the remainder of this text because of 
its ease of understanding , and because individual byte addresses are 
unnecessary, although for an explanation of a particular mode the byte 
representation may be used. 

In this example, only direct addresses were used. A program to 
reduce the number of bytes required to move the five values follows: 
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Move 


FIELD 1 


to 


FIELD 2 






Add 1 


to FIELD 1 


Address 


1 


Add 1 


to FIELD 2 


Address 



Is FIELD 2 Address = End of FIELD2 
7 

If Yes 

Done 



Moving Five Bytes of Data with Loop 
FIGURE 6.1 



Example 
Example 



INIT 

START 

OTHER 



6.2 is a program listing that corresponds to the flow chart: 
6.2: Moving Five Bytes of Data With Loop 

COMMENTS 



INSTRUCTION 
CLC 
LDA 
STA 
LDA 
ADC 
STA 
LDA 
ADC 
STA 
CMP 
BNE 



OPERAND 



FIELD 1 

FIELD 2 

START + 1 

//I 

START + 1 
OTHER + 1 

in 

OTHER +1 

AFIELD 2+5- 
START 



J 



Move Loop 

Modify Move Values 
Check for End 



For ease of reading, labels have been written in the form 
"FIELD 1". This is incorrect format for use in the various 
symbolic assemblers. "FIELD 1" must be written "FIELDl" 
when coding for assembler formats. 
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Assuming Zero Page, direct addressing. Example 6.3 Is written 
below with one byte per line just as it would appear in program memory. 
This will provide a more detailed description of Example 6.2. 



Example 6.3 : Coded Detail of Moving Fields With Loop 



LABEL 

INIT 

START 

OTHER 



CODE NAMES 

CLC 

LDA 

FIELD 1 
STA 

FIELD 2 
LDA 

START + 1 

ADC 

1 

STA 

START + 1 
LDA 

OTHER + 1 

ADC 

1 

STA 

OTHER + 1 
CMP 

ORIGINAL FIELD 2+5 

BNE 

START 



COMMENTS 
Clear Carry 
(FIELD 1)-^A 



(FIELD 2) 
From Address—^A 
A + l->-A 
A— ^ From Address 
To Address A 
A + 1-^A 
A-^-To Address 
A - ORIGINAL FIELD 2+5 
If not, loop to START 



In this example, the program is modifying the addresses of one 
load instruction and one store instruction rather than writing 10 in- 
structions to move five bytes of data and 50 instructions to move 
25 bytes of data. 

The address of the Load A instruction is located in memory at 
START +1, and the Store instruction at OTHER +1. In order to perform 
this operation, the address must be modified once for each move opera- 
tion until all of the data are moved. 

Checking for the end of the moves is accomplished by checking the 
results of the address modification to determine if the address exceeds 
the end of the second field. When it does so. the routine is complete. 
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If 100 values were to be moved this program would remain 20 bytes 
long, whereas the solution to the first problem would require a program 
of 200 instructions. 



The type of coding used in this example is called a "loop." 
Although -the program loop in this case requires as many bytes as the 
original program, more values could be moved without increasing the 
length of, the program. The greater the number of repetitive operations 
that are to be accomplished, the greater the advantage of the loop 
type program over straight line programming. 

Important Note : The execution time required to move the five 
values is significantly longer using the loop program than the straight 
line program. In the straight line program, if a Zero Page operation 
is assumed, the time to perform the total move is 30 cycles. Using 
the loop program, the execution time to move five values is five times 
through the entire loop, which takes 25 cycles. ' Therefore the time 
to move five values is 125 cycles. 

While loops have an advantage in coding space efficiency, all loops 
cost time. If the programmer has a problem that is extremely time- 
dependent, taking the loop out and going to straight line programming, 
even though it is extremely inefficient in terms of its utilization of 
memory, will often solve the timing problem. 

The straight line programming technique becomes very useful in some 
control applications. However, it is not recommended as a standard 
technique, but should be used only when there are extreme timing problems. 
Loops will normally save a significant number of bytes but they will 
always take more time. 

The technique used in the loop program example has two major 
problems : 

1. The necessity to modify program memory. This should be 
avoided to take advantage of the ability to put programs 
into read-only memory with the corresponding savings in 
hardware costs. 
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2. Although this is the simplest form of computed addressing, 

fewer program bytes would be necessary with the more sophisti- 
cated form of pro^^ram shown in the following flow chart. 




Moving Five Bytes of Data with Counter 
i' f CURE 6.2 



In the K6500 System's microprocessor family, the counter is called an 
Undex register. Tt is an 8-bit register which is loaded from memory and 
I has the ability to have 1 added to it by an increment instruction (INX,INY) 
[and can be compared directly to memory using ttie compare index instruction 
[UCPX.CPY). Example 6,4 shows the program listing for the flow chart of 
|, Figure 6.2. 
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Revised 2/79 



Example 6.^ : Moving Five Bytes of Data VJith Index Refiistcr 



BYTES LABEL INSTRUCTION OPERAND COMMENTS 



2 LDX Load Index With Zero 

3 LOOP LDA FIELD l.X 
3 STA FIELD 2.X 

^ Increment Count 

2 5 Compare For End 

2 BNE LOOP 



13 for Absolute 

In this example, index register X is used as an index and as a 
counter. It is initialized to zero. Data are fetched from memory at 
the address "FIELD 1 plus the value of register X", and placed in A. 
The data are then written from A to memory at the address "FIELD 2 plus 
the value of register X." Register X is incremented by 1 and compared 
with five in order to determine if all five data values have been 
transferred. If not the program loops back to LOOP. In this example, 
"FIELD 1" is called the "Base Address" which is the address to which 
indexing is referenced. 

This only takes 11 or 13 bytes, depending on whether or not the 
field is in Page Zero or in absolute memory. It still requires 13 or 15 
cycles per byte moved, again confirming that loops are excellent for 
coding space but not for execution time. 

It can be seen from the example that there are basically two 
criteria for an index register: 1) that it be a register which is 1| 
easily incremented, compared, loaded, and stored; and 2) that in a 
single instruction one can specify both the Base Address and the index 
register to be used. 

In a R6500-series microprocessor, the indexed instruction is sym- 
bolically represented by "OP CODE Address. X." This indicates to the 
symbolic assembler that an instruction OP CODE should be picked, which 
should specify either the absolute address modified by the content of 
index X register or Zero Page address modified by the content of index 
X register. 
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In performing these operations, the microprocessor fetches the 
instruction OP CODE as previously defined, and fetches the address, 
modifies the address from the memory by adding the index register to 
it prior to loading or storing the value of memory. 

The index register is a counter. As discussed previously, one 
of the advantages of the flags in the microprocessor is that a value 
can be modified and its results tested. Assume that the last example is 
modified so that instead of moving the first value in FIELD 1 to the 
first value in FIELD 2, the last value in FIELD 1 is moved first to the 
last value in FIELD 2, then the next to the last value, etc. and finally 
the first value. With the index register preloaded with five and using 
a decrement instruction, the contents of the index register would end 
at zero after the five fields of data were transferred. The zero 
indicates that the number of times through the loop is correct and 
the loop exited by use of the zero test. The program listing for 
this modification is shown in Example 6.5: 



Example 6.5 : Moving Five Bytes of Data by Decrementing the Index 
Register 

LABEL INSTRUCTION OPERAND 



LDX 5 

LOOP LDA FIELD 1-1. X 

STA FIELD 2-1, X 
DEX 

BNE LOOP 

In this example, Index Register X is again used as an Address 
Counter but it will count backwards. It is initialized to five for 
this example. Data are fetched from memory at the address "FIELD 1-1 plus 
the value of Register X" and placed in A. The data are then written 
from A to memory at the address "FIELD 2-1 plus the value of Register X." 
Register X is decremented by one. If tlie decremented value is not zero, 
as determined by a Branch on Zero instruction, the program loops back 
to LOOP. 



The loop has been decreased to 9 or 11 bytes, and the execution 
time per byte has been decreased from 15 cycles to 13 cycles per value 
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which shows the advantage of using the flag setting of the decrement 
index instruction. 

The two index registers, X and Y, can now be added to the 
system block diagram as in Figure 6.3. 



INDEX 
Y 



INDEX 
X 



IT 



I INTERNAL ADH 
O 

I ^S, I 



Partial Block Diagram of a R6500 Microcomputer System Microprocessor Including Index Registers 

FIGURE 6.3 



Each of the index registers is 8 bits long and is loaded and stored 
from memory, using techniques similar to the accumulator. Because of this 
ability, the registers can be considered as auxiliary channels to flow data 
through the microprocessor. However, their primary use is in being 
added to addresses fetched from memory to form a modified effective 
address, as described previously. Both index registers have the ability 
to be compared to memory (CPX,CPY) and to be incremented (INX,INY) and 
decremented (DEX,DEY) . 
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Because of OP CODE limitations, X and Y have slightly different 
applications. X is a little more flexible because it has Zero Page 
operations which Y does not have with exception of LDX and STX. Aside 
from which modes they modify, the registers are autonomous, independent 
and of equal value. 



6.1 AUSOLUTL !NDl-:Xi;D 

Absolute indexed address is effective addressing with an index 
register added to the absolute base address. The sequences that occur 
for absolute indexed addressing without page crossing are as follows: 



Example 6.6 : Absolute Indexed; with No Page Crossing 



Address 
Cycle Bus 

1 0100 



0101 



0102 



Data 
Bus 

OP CODE 



BAL 



BAH 



BAH,BAL+X OPERAND 



External 
Operation 

Fetch OP CODE 



Fetch BAL 



Fetch BAH 



Put Out 

Effective 

Address 



1 nterna 1 
Opera tion 

Increment PC to 101, 
Finish Previous 
Instruction 

Increment PC to 102, 
Interpret In- 
struction 

Increment PC to 103, 
Calculate BAL + X 



103 



Next OP 
CODE 



Fetch Next 
OP CODE 



Finish Operations 



BAL and BAH refer to the low- and high-order bytes of the base address, 
respectively. While the index X was used in Example 6.7, the index Y 
is equally a[>i) 1 i cab 1 e , 

If a page is not crossed, the results of the address low + X does 
not cause a carry. The processor is able to pipeline the addition of the 
8-bit index register to the l(jwer byte of the base address (BAL) and not 
suffer any time degradation for absolute indexed addressing over straight 
absolute addressing. In other words, while BAH is being fetched, the 
add of X to BAL occurs. Both addressing modes require four cycles, with 
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the only difference being that X or Y must be set at a known value 
and the OP CODE must indicate an index X or Y. 

The second possibility is that when the index register is added 
to the address low of tht; base address that the resultant address is 
in the next page. This Is illustrated in Example 6.7. 

Example 6.7 : Absolute Indexed; with Page Crossing 



Cycle 
1 



Address Data 
Bus Bus 



0100 



0101 



OP CODE 



BAL 



External 
Operation 

Fetch OP CODE 



Fetch BAL 



Internal 
Operation 

Finish Previous 
Operation Increment 
PC to 101 

Interpret Instruction 
Increment PC to 102 



0102 



BAH 



Fetch BAH Add BAL + Index 

Increment PC to 103 



BAH, BAL Data 
+X (Ignore) 



BAH+1 , 
BAL+X 



0103 



Data 



Next OP 
CODE 



Fetch Data 
(Data is 
ignored) 

Fetch Data 



Fetch Next 
OP CODE 



Add BAH + Carry 



Finish Operation 



The most substantial difference between the page crossing operation 
and no page crossing is that, during the fourth cycle, the address 
high and the calculated address low are put out, thereby Incorrectly 
addressing the same page as the base address. This operation is carried 
on in parallel with the adding of the carry to the address high. During 
the fourth cycle the address high plus the carry from the adder are put 
on the address bus, moving the operation to the next page. Thus, there ^ 
are two effects from the page crossing: the first effect is the address- 
ing of a false address; this is similar to what happens in a branch rela- 
tive during a page crossing. Secondly, the operation takes an additional 
cycle while the new address high is calculated. As with the branch relat 
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this page crossing occurs independently of programmer action and 
there is no penalty in memory for having crossed the page boundary. 
It is possible for the programmer to predict a page crossing by 
knowing the value of the base address and the maximum offset value 
in the index register. If timing is of concern, the base address 
can be adjusted so that the address field is always in one page. 

As with absolute addressing, absolute indexed is the most 
general form of indexing. It is possible to do absolute indexed 
modified by X, and absolute indexed modified by Y. Instructions 
which allow absolute indexed by X are ADC, AND, ASL, CMP, DEC, 
EOR. INC, LDA, LDY, LSR, ORA , ROL, ROR, SBC, and STA. 

The instructions which allow indexed absolute by Y are ADC, 
AND, CMP, EOR, LDA, LDX, ORA. SBC, and STA. 



6,2 ZERO FA(JE INDEXED 

As with non-computed addressing, there is a memory use advantage 
tothe short-cut of zero page addressing. Except in LDX and STX 
instructions which can be modified by Y, Zero Page is only available 
•Odlfied by X. If the base address plus X exceeds the value that 
can be stored in a single byte, no carry is generated; therefore 
there is no page crossing phenomenon. A wrap-around will occur within 
Pige Zero. The following example illustrates the internal operations 
of Zero Page indexing. 
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Example 6.8 : Illustration of Zero PaRe Indexing 



Cycle 
1 



Address 
Bus 



0100 



010^ 



00 . BAL 



Data 
Bus 



OP CODE 



BAL 



Data 
(Dis- 
carded 



External 
Operation 

Fetch OP CODE 



Fetch Base 
Address Low 
(BAL) 

Fetch 

Discarded 

Data 



Internal 
Operation 

Finish Previous 
Operation, OiUl 

Interpret Instruct 
ion, 0102 PC 

Add: BAL + X 



00, BAL 
+X 



Data 



Fetch Data 



0102 



Next OP 
CODE 



Fetch Next OP 
CODE 



Finish Operation 



As can be seen from the example. Zero Page indexing offers no 
time savings over absolute indexing without page crossing. In the case 
of the indexed absolute, during cycle 3 the address high is being 
fetched at the same time as the addition of the index to address low. 
In the case of the Zero Page, there is no opportunity for this type of 
overlap; therefore, indexed Zero Page instructions take one cycle longer 
than non-indexed instructions. 

In both Zero Page indexed and absolute indexed with a page crossing, 
there are incorrect addresses calculated. Provisions have been made to 
make certain that only a READ operation occurs during this time. Memory 
modifying operations such as STORE. SHIFT, ROTATE, etc. have all been 
delayed until the correct address is available, thereby prohibiting any 
possibility of writing data in an incorrect location and destroying 
the previous data in that location. 

As has been previously stated, there is no carry out of the Zero 

Page operation. 00 is forced into address high under all circumstances 

in cycle 4. For example, if the index register containing a value 

of 10 is to be added to base address containing a value of F7. the 
following operation would occur: 



6-lA 



Example 6.9 : Demonstrating the Wrap-Around 



Cycle 

3 
A 



Address Bus 



00F7 
0007 



Internal Operation 
F7 + 10 



This indicates the wrap-around effect that occurs with Zero Page 
indexing with page crossing. This wrap-around does not increase the 
cycle time over that shown in the previous example. 

Only index X is allowed as a modifier in Zero Page. Instructions 
which have this feature include ADC, AND, ASL, CMP, DEC, EOR, INC, LDA, 
LDY, LSR, ORA, ROL, ROR, SBC, STA and STY. Note that index Y is allowed 
in the instructions LDX and STX. 

6.3 IND/RtCT ADDRt:SSING 

In solving a certain class of problems, it is some times necessary 
to have an address which is a truly computed value, not just a base 
address with some type of offset, but a value which is calculated or 
sometimes obtained as a group of addresses. In order to implement 
this type of indexing or addressing, the use of indirect addressing 
has been introduced. 

In the R65O0-series microprocessors, indirect operations have a 
special form. The basic form of the indirect addressing is that of an 
Instruction consisting of an OP CODE followed by a Zero Page address. The 
i microprocessor obtains the effective address by picking up from the Zero 
Page address the effective address of the operation. The indirect 
.addressing operation is much the same as absolute addressing, except that 
'i indirect addressing uses a Zero Page addressing operation to 
access the effective address. In the case of absolute 

addressing, the value in the program counter is used as the address to 
pick up the effective address low, and one is added to the program counter 
Vfhlch is used to pick up the effective address high. In the case 
of indirect addressing, tlie next value after the OP CODE, as addressed 
with the program counter, is used as a pointer to address the effective 
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address low in the zero page. The pointer is then incremented by 
one with the effective address high fetched from the next memory 
location. The next cycle places the effective address high (ADH) and 
effective address low (ADL) on the address bus to fetch the data. 
An illustration of this is shown in Figure 6. A. 



0100 OP CODE 
0101 



lAL 



00, 
lAL 



00,IAL+1 



ADL 



ADH 



pADL, I 

ADH DATA 



Indirect Addressing-Pictorial Drawing 
FIGURE 6.4 



The addi^ess following the instruction is really the address of an 
address, or "indirect" address. The indirect address is represented 
by lAL in the figure. 

A more detailed definition of indirect addressing is included in 
the appendix. 
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Although the R6500 System's microprocessor family has indirect 
operations, it has no simple indirect addressing, except for JMP instruc- 
tions, such as described above. Instead, there are two modes of indirect 
addressing: 1) indexed indirect and 2) indirect indexed. The two modes 
are discussed in Sections 6. A and 6.5, respectively. 



6.4 INDEXED INDIRECT ADDRESSING 

The major use of indexed indirect is in picking up data from a 
table or list of addresses to perform an operation. Examples where 
indexed indirect is applicable are found in polling I/O devices or in 
performing string or multiple-string operations. Indexed indirect 
addressing uses the index register X. Instead of performing the indi- 
rect as shown in Figure 6.4, the index register X is added to the Zero 
Page address, thereby allowing varying address for the indirect pointer. 
The operation and timing of the indexed indirect addressing is depicted 
in Figure 6.5. 



0100 OP CODE 



0101 lAL 



00,IAL+X 



\ 



00,IAL+0 



ADL 


1 




ADH 


1 




ADL 


2 




ADM 


2 




ADL 


3 




ADH 


3 



ADHl, 
ADH 



ADH2, 
ADL2 



DATA 1 



DATA 2 



ADH3, 

ADL3 IMTA 3 



Indexed Indirect Addressing 
FIGURE 6.5 
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Example 6.10 : Illustration of Indexed Indirect Addressing 



Cycle 
1 



Address Data 
Bus Bus 



0100 



0101 



OP CODE 



BAL 



00,BAL DATA (Dis- 
carded) 

00, BAL ADL 
+ X 

00, BAL ADH 
+ X + 1 



External 
Operation 

Fetch OP CODE 
Fetch BAL 



Fetch Discard- 
ed DATA 



Fetch ADL 



Fetch ADH 



Internal 
Operation 

Finish Previous 
Operation, 0101 PC 

Interpret In- 
struction, 0102 PC 

Add BAL + X 



Add 1 to BAL + X 



Hold ADL 



ADH, ADL DATA 
0102 Next OP 



Fetch DATA 

Fetch Next OP 
CODE 



Finish Operation 
0103 ^ PC 



One of the advantages of this type of indexing is that a 16-bit 
address can be fetched with only two bytes of memory, the byte that 
contains the OP CODE and the byte that contains the indirect pointer. 
It does require, however, that there be a table of addresses kept in 
a read/write memory which is more expensive than having it in read- 
only memory. Therefore, this approach is normally reserved for appli- 
cations where use of indexed indirect results in significant coding 
improvement or whare the address being fetched is a variable computed 
address. 



It is also obvious from the example that the user pays a minor time 
penalty for this form of addressing in that indexed Indirect always takes 
six cycles to fetch a single operand, which is 25% more than an absolute 
address and 50% more tlian a Zero Page reference to an operand. As in 
the Zero Page indexed, the operation in cycles three and four are 
located in Zero Page and there is no ability to carry over into the next 
page. It is possible to develop a value of the index plus the base 
address where the result exceeds 255; in this case, the address put out 
is a wrap-around to the low part of the Page Zero. 
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Instr uctions wliich allow the use of indexed indirect are ADC, AND, 
CMP, EOR, LDA, ORA, SBC, and STA. 



6.5 INDIIU:CT INDLXI:D ADUlU-SSiNG 

The indirect indexed instruction combines a feature of indirect 
addressing and a capability of indexing. The usefulness of this in- 
struction is primarily for those operations in which one of several 
values could be used as part of a subroutine. By having an indirect 
pointer to the base operation and by using the index register Y in 
the normal counter type form, one can liave the advantages of an 
address that points anywhere in memory, combined with the advantages 
of the counter offset capability of the index register. 

Figure 6.6 illustrates the indirect indexed concept in flow form 
while Example 6.11 indicates the internal operation of a non-page roll- 
over of an indirect index. 



0100 OP CODE 
0101 



lAL 



[OO.IAL 

00, IAL+1 



BAL 



BAH,BAL+Y 
(ADH, ADL) 



[b 



I BAH, 
BAL 



RAH , 
BAL+1 

BAH , 
BAL+2 



DATA 


1 




DATA 


2 




DATA 


3 



fncUrccI indexed Addressing 
i'lGUl<E() 6 
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Example 6.11 : Indirect Indexed Addressing (No Page Crossing) 

Address Data External Internal 

Cycle Bus Bus Operation Operation 

1 0100 OP CODE Fetch OP CODE Finish Previous 

Operation, 0101 

2 0101 lAL Fetch lAL Interpret In- 

struction, 0102 -♦■ 

3 00,IAL BAL Fetch BAL Add 1 to lAL 

A 00,IAL BAH Fetch BAH Add BAL + Y 
+ 1 

5 BAH, BAL DATA Fetch Operand 

+ Y 

6 0102 Next OP Fetch Next OP Finish Operation 

CODE CODE 0103 PC 



The indirect index still requires two bytes of program storage — one 
for the OP CODE, one for the indirect pointer. Once beyond the indirect, 
the indexing of the indirect memory location is just the same as though 
it were an absolute indexed operation, in the sense that if there is no 
page crossing, pipelining occurs in the adding of the Index register Y to 
address low while fetching address high, and, therefore, the non-page 
crossing solution is one cycle shorter than the indexed indirect. In 
Example 6.12 it is seen that the page crossing problem that occurs with 
absolute indexed page crossing also occurs with indirect indexed address- 
ing. 
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Example 6.12 : Indirect Indexed Addressing (With Page Crossing) 



Cycle 
1 



Address Data 
Bus Bus 



0100 



0101 



OP CODE 



lAL 



OO.IAL BAL 

00,IAL BAH 
+ 1 

BAH. BAL DATA (Dis- 
+ Y carded) 

BAH + 1 DATA 
BAL + Y 

0102 Next OP 
CODE 



External 
Operation 

Load OP CODE 



Fetch lAL 

Fetch BAL 
Fetch BAH 



Fetch DATA 
(Discarded) 

Fetch Data 



Fetch Next OP 
CODE 



Internal 
Operation 

Finish Previous 
Operation, 0101 -+ PC 

Interpret In- 
struction, 0102 PC 

Add 1 to lAL 

Add BAL to Y 

Add 1 to BAH 



Finish This 
Operation, 
0103 PC 



When there Is a page crossing, the base address high and base 
address low plus Y are pointing to an incorrect location within a 
referenced page. However, it should be noted that the programmer has 
control of this incorrect reference In the sense that it is always 
pointing to the page of the base address. In one more cycle the correct 
address is referenced. As was true in the case of absolute Indexed, 
the data at the incorrect address is only read. STA and the various 
read, modify, and write memory commands all operate assuming that there 
will be a page crossing; take the extra cycle time to perform the add 
and carry; and perform a write only on the sixth cycle, rather than 
taking advantage of the five-cycle short-cut which is available to 
read operations. This added cycle guarantees that a memory location 
will never be written into with incorrect data. 



Instructions which allow the use of indexed indirect are ADC, AND, 
CMP, EOR, LDA, ORA, SBC, and STA. 



6-21 



In the following two examples a comparison can be seen between 
the use of absolute modified by Y and indirect indexed addressing. 



In both examples, the same function is performed. Values from 
two memory locations ^re added, and the result is stored in a third 
memory location, assuming that there are several values to be added. 



The first example deals with known field locations. The second 



example. 


such as 1 


night be traditionally used in subroutines, deals 




with field locations that vary between routines. ^ 


I two-byte pointer 




for each 


routine 


using the subroutine is stored in 


Page Zero, The 




number of values 


to be added for each routine is al 


.so stored. 




c-..„ 1 „ A 11 


: Absolute Indexed Add — Sample 


Program 




//Bytes 


Cycles 


Label InsLrucLion 


Coinmcnts 




2 


2 


START LUY //COUNT -1 


Set Y = End of FIELD 




3 




LOOP LDA FIELD 1,Y 


Load Location 1 




3 




ADC FIELD 2,Y 


Add Location 2 




3 




STA FIELD 3.Y 


Store in Location 3 




1 


2 


DEY 






2 


3 


BPL LOOP 


Check for Less Than 




T4 




Time for 10 Bytes 


= 171 Cycles 






: Indirect Indexed Add — Sample 


Program 






Cycles 


Label Instruction 


Comments 




//Bytes 
2 


2 


START LDY //COUNT -1 


Set Y = End of FIELD 




2 


5 


LOOP LDA (PNTl) , Y 


Load FIELD 1 Value 




2 


5 


ADC (PNT2) , Y 


Add FIELD 2 Value 




2 


5 


STA (PNT3) , Y 


Store FIELD 3 Value 


i1 


1 


2 


DEY 






2 


3 


BPL LOOP 




m 


IT 


Y2 


Time for 10 Bytes 


= 201 Cycles 




+ 


6 Bytes 


for Pointers 




['1,1 



iri 



6-22 



The "count" term in these examples reprt jents the number of sets 
of values to be added and stored. Loading the index register with 
COUNT-1 will allow a fall through the BPL instruction when computation 
on all set of values has been completed. 

There is a definite saving in program storage using indirect be- 
cause it requires only two bytes for each indirect pointer, the OP CODE 
plus the pointer of the Page Zero location, whereas in the case of the 
absolute, it takes three bytes, the OP CODE, address low and address 
high. 

It is to be noted that there are six bytes of Page Zero memory used 
for pointers, two bytes for each pointer. The number of memory locations 
allocated to the problem are 17 for the indirect and 14 for the problem 
where the values are known. The execution time is longer in the in- 
direct loop. Even though the increase in time for a single pass 
through the loop is only three cycles, if many values are to be trans- 
ferred, it adds up. It is important to note that loops require time 
for setup but this time is consumed only once. In the loop itself, 
however, additional time is multiplied by the number of times the pro- 
gram goes through the loop; therefore, on problems where execution time 
is important, the time reduction effort should be placed on the loop. 

Even though the loop time is longer and the actual memory expended 
is greater for the indexed indirect add, it has the advantage of not 
requiring determination of the locations of FIELD 1, FIELD 2, and FIELD 
3 at the time the program was written as is necessary with absolute. 

An attempt to define problems to take advantage of this shorter 
memory and execution time by defining fields should be investigated 
first. However, in almost every program, the same operation must be 
performed several times. In those cases, it is sometimes more useful 
to define a subroutine, and to set the values that the subroutine will 
operate on as fields in memory. Pointers to these fields are placed 
in the Zero Page of memory, and then the Indexed indirect operation is 
used to perform the function. This is the primary application of the 
indexed indirect operation. 
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6.6 INDiRliCT AbSOLVrt: 



In the case of all of the indirect operations previously described, 
the indirect reference is always to a Page Zero location from which 
are picked up the effective address low and effective address high. 
There is an exception in the R650O-series microprocessor family for the 
jump instruction in which absolute indirect jumps are allowed. The use 
of the absolute indirect jump is best described in the discussion on 
interrupts where the addressing mode and its capabilities are explained. 

6. 7 APPLICA TION OF INDbXkS 

As has been developed in many of the previous examples, an index 
register has primary values as a modifier and as a counter. As a 
modifier to a base add^ress operation, it allows the accessing of 
contiguous groups of data by simple modification of the index. This 
is the primary application of indexes, and it is for this purpose that 
they were created. By virtue of the fact that all of the R650O instruc- 
tions have the base address in the instruction or, in the case of the in- 
direct, in the pointer, a single index can usually service an entire 
loop, because each of the many instructions in the loop are normally 
referring to the same relative value in each of the lists. An example 
is adding the third byte of a number to the corresponding third byte 
of another number, then storing the result in the memory location 
representing the third byte of the result; therefore, the index register 
needs to contain only three to accomplish all three of these offset 
functions . 

In some other microprocessors internal registers serve as indirect 
pointers. The single register requirement is a significant advantage 
of the type of indexing done in the R6500. Even though the R6500 has 
two indexes, more often than not , a single index will solve many of 
the problems because of the fact that the data is normally organized 
in corresponding fields. 

The second feature of the R6500 type of indexing is that, if applied 
properly, the index register also contains the count of the operations 
to be performed. 
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The examples given in this manner are presented in an attempt to show 
how to take advantage of that feature. There are two approaches to counting: 
forward counting and reverse counting. In forward counting, the data in 
memory can be organized in such a manner that the index register starts at 
zero and is added to on each successive operation. The disadvantage of this 
type of approach is that the compare index instruction, as used in Example 
6.13, must be inserted into the loop in order to determine that the cor- 
rect number of operations is completed. 

The reverse counting approach has been applied in the latter 
examples. The data must be organized for reverse counting operation. 
The first value to be operated on is at the end of the FIELD, the 
next value is one memory location in front of that, etc. The ad- 
vantage of this type of operation is that it takes advantage of the 
combined decrement and test capability of the processor. There are 
two ways to use the test. First there is the case where the actual 
number of operations to be performed is loaded into the index register 
as was done in Example 6.13. In this case, the index contains the cor- 
rect count but if added to the base directly, would be pointing to one 
value beyond the FIELD because the base address contains the first byte. 
Therefore, when using the actual count in the index register, one always 
references to the base address minus one. This is easily accomplished as 
shown in the examples. The assembler accepts symbolic references in the 
form of base address minus one, and the microprocessor very carefully per- 
forms the operation shown. 

The advantage of putting the actual count in the register is 
that the branch if not equal Instruction (BNE) can be used because 
the value of the register goes to zero on the last operation. 

The second alternative is to load the counter with the count 
minus one as done in Example 6.1A. In this case, the actual value of 
the base address is used In the offset. However, the branch back 
to loop now is a branch plus, remembering that the value in the index 
register will not go to minus (all ones) until one decrement is past 
zero . 
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Values of count minus one through zero will all take the branch. 
It is only when attempting to reference less than the base address 
that the loop will be completed. 

Either approach gives minimum coding and requires only that 
the user develop a philosphy of always organizing his data with 
the first value at the end. In many cases, the operations such as 
MOVE can be performed even if the data is organized the other way. 
Experienced programmers find that this reverse- counting form is 
actually more convenient to use and always results in minimum loop 
time and space. 

Although for most applications, the 8-bit index register permits 
simple count in offset operations, there are a few operations where 
the 256 count that is available in the 8-bit register is not adequate 
to perform the indexed operations. There are two solutions to this 
problem. First to code the program with two sets of bases — that 
is, to duplicate the coding for the loop with two different address 
highs, each a page apArt . The second, more useful solution, is 
CO go to indirect operations because the indirect pointer can be 
modified to allow an infinite indexed operation. An example of the 
move done under 256 and over 256 is shown in the following examples: 

Example: 6.15 : Move N Bytes (N < 256) 

Number of Program Instruction OPERAND 

w J ^„ T^TTTT n r.nmTTipnts 



Cycles Label Mnemonics FIELD Comments 



2 LDX //BLOCK Set Up 2 Cycles 

A LOOP LDA FR0M-1,X 

1 STA TO -1,X LOOP Time: 

2 DEX 13 Cycles 

3 BNE LOOP 



Memory Required: 
11 Bytes 
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Example 6.16 : Move N Bytes (N < 256) 



Number of 
Cycles 

2 
3 
2 
3 



Progra 
Label 

MOVE 



Instruction 
Mnemonics 

LDA 
STA 
LDA 
STA 



operand 
FIELD 

//FROML 
FRPOINT 
//FROMH 
FRPOINT 



+ 1 



Comments 



Move FROM Address to 
an Indirect Pointer 



LOOP 



SPECIAL 



LDA 

STA 
LDA 
STA 
LDX 
LDY 
LDA 
STA 
DEY 
BNE 
INC 
INC 
DEX 
BMI 
BNE 
LDY 
BNE 



OUT 



//TOL 

TOPOINT 
//TOH 

TOPOINT + 1 

//BLOCKS 

//O 

(FRPOINT) ,Y 
(TOPOINT), Y 

LOOP 

FRPOINT + 1 
TOPOINT + 1 

OUT 
LOOP 
//COUNT 
LOOP 

Memory Required: 
40 Bytes 



Move TO Address 

to an Indirect Pointer 



Setup Number of 256 
Blocks to Move 
Loop Time: 16 Cycles/ 
Byte. Move 256 Bytes 



Increase High 
Pointer 

Check for Last Move 



Set Up Last Move 
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CHAPTER 7 



INDEX REGISTER INSTRUCTIONS 



The index registers can be treated as auxiliary general-purpose reg- 
isters, having the added ability of being incremented and decremented 
because of the normal operations which they are required to perform. 

7.0 LDX - LOAD INDEX REGISTER X FROM MEMORY 

Load the index register X from memory. 
The symbolic notation is M X. 

LDX does not affect the C or V flags; sets Z if the value 
loaded was zero, otherwise resets it; sets N if the value loaded in 
bit 7 is a 1, otherwise N is reset; and affects only the X register. 
The addressing modes for LDX are Immediate; Absolute; Zero Page; 
Absolute Indexed by Y; and Zero Page Indexed by Y. 

7.1 LDY-- LOAD INDEX REGISTER Y FROM MEMORY 

Load the index register Y from memory. 
The symbolic notation is M Y. 

LDY does not affect the C or V flags, sets the N flag if the 
value loaded in bit 7 is a 1. otherwise resets N; sets Z flag if the 
loaded value is zero, otherwise resets Z; and affects only the Y reg- 
ister. The addressing modes for load Y are Immediate; Absolute; 
I Zero Page; Zero Indexed by X, Absolute Indexed by X. 



1.2 SIX - STORE INDEX REGISTER X IN MEMORY 

Transfers value of X register to addressed memory location. 
The symbolic notation is X M. 

No ^.lags or registers in the microprocessor are affected by 
the store operation. The addressing modes for STX are Absolute, 
Zero Page, and Zero Page Indexed by Y. 

7.3 STY - STORE INDEX REGISTER Y IN MEMOR Y 

Transfer the value of the Y register to the addressed memory 
location. The symbolic notation is Y M. STY does not affect any 
flags or registers in the microprocessor. The addressing modes for 
STY are Absolute; Zero Page; and Zero Page Indexed by X. 

7.4 INX - INCREMENT INDEX REGISTER X BY ONE 

Increment X adds 1 Co tlie current value of the X register. Tliis 
is an 8-bit increment which does not affect the carry operation, there- 
fore, if the value of X before the increment was FF, the resulting 
value is 00. The symbolic notation is X + 1 > X. INX does not affect 
the carry or overflow flags; it sets the N flag if the result of the 
increment has a one in bit 7, otherwise resets N; sots tlie Z flag if 
the result of the increment is 0, otherwise it resets the Z flag. 
INX does not affect any other register other than the X register. INX 
is a single byte instruction and tlie only addressing mode is Implied. 

7.5 IN Y - INCREMENT INDEX REGISTER Y BY ONE 

Increment Y increments or adds one to the current value in the 
Y register, storing the result in the Y register. As in the case of 
INX the primary application is to step through a set of values using 
the Y registef. The symbolic notation is Y + 1 Y . The INY does not 
affect the carry or overflow flags; sets the N flag if the result of 
the increment has a one in bit 7, otherwise resets N; sets Z if 
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as a result of the increment the Y register is zero, otherwise resets 
the Z flag. Increment Y Is a single-byte Instruction and the only 
addressing mode is Implied, 

7.6 DEX - DECREMENT INDEX REGISTER X BY ONE 

This instruction subtracts one from the current value of the 
index register X and stores the result in the index register X. 

The symbolic notation is X - 1 X. 

DEX does not affect the carry or overflow flag, it sets the 
N flag if it has bit 7 on as a result of the decrement, otherwise 
it resets the N flag; sets the Z flag if X is a as a result of 
the decrement, otherwise it resets the Z flag. 

DEX is a single-byte instruction, the addressing mode Is 
Implied . 

7.7 DEY - DECREMENT INDEX REGISTER Y BY ONE 

This instruction subtracts one from the current value in the in- 
dex register Y and stores the result into the index register Y. The 
result does not affect or consider carry so that the value in 
the index register Y is decremented to and then through to FF. 

Symbolic notation is Y - 1 ^ Y. 

Decrement Y does not affect the carry or overflow flags; if the 
Y register contains bit 7 on as a result of the decrement the N flag 
is set, otherwise the N flag is reset. If the Y register is as a 
result of the decrement, the Z flag is set, otherwise the Z flag is 
reset. This instruction affects only the index register Y, 

DEY is a single- byte instruction and the addressing mode is 
Implied . 

NOTE : Decrement of the index registers is the most convenient 
method of using the index registers as a counter, in that the decre- 
ment involves setting the value N as a result of having passed 
through and sets Z when the results of the decrement are 0, 
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7.8 CPX " COMPARE INDEX REGISTER X TO MEMOR Y 

This instruction subtracts the value of the addressed memory 
location from the content of index register X using tlie adder but 
does not store the result; therefore, its only use is to set the 
N, Z and C flags to allow for comparison between the index register 
X and the value in memory. 

The symbolic notation is X - M. 

The CPX instruction does not affect any register in the machine; 
it also does not affect the overflow flag. It causes the carry to be 
set on if the absolute value of the index register X is equal to or 
greater than the data from memory. If the value of the memory is 
greater than the content of the index register X, carry is reset. 
If the results of the subtraction contain a bit 7, then the N flag 
is set, if not, it is reset. If the value in memory is equal to the 
value in index register X, the Z flag is set, otherwise it is reset. 

The addressing modes for CPX are Immediate, Absolute and Zero 

Page. 

7.9 CPY - COMPARE INDEX REGISTER Y TO MEMORY 

This instruction performs a two*s complement subtraction between 
the index register Y and the specified memory location. The results 
of the subtraction are not stored anywhere. The instruction is strict- 
ly used to set the flags. 

The symbolic notation for CPY is Y - M. 

CPY affects no registers in the microprocessor and also does not 
affect the overflow flag. If the value in the index register Y is 
equal to or greater than the value in the memory, the carry flag will 
be set, otherwise it will be cleared. If the results of the subtract- 
tion contain bit 7 on the N bit will be set, otherwise it will be 
cleared. If the value in the index register Y and the value in the 
memory are equal, the zero flag will be set, otherwise it will be 
reset . 

The addressing modes for CPY are Immediate, Absolute and Zero Page 
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7 JO TRANSFERS BETWEEN THE INDEX REGISTERS AND ACCUMULATOR 

There are four instructions which allow the accumulator and in- 
dex registers to be interchanged. They are TXA, TAX which transfer 
the contents of the index register X to the accumulator A and back, 
and TYA, TAY which transfer the contents of the index register Y to 
the accumulator A and back. The usefulness of these will be discussed 
after the instructions . 

7.H TAX - TRANSFER ACCUMULATOR TO INDEX X 

This instruction takes the value from accumulator A and trans- 
fers or loads it into the index register X without disturbing the 
contents of the accumulator A. 

The symbolic notation for this is A X. 

TAX only affects the index register X, does not affect the 
carry or overflow flags. The N flag is set if the resultant value in 
the index register X has bit 7 on, otherwise N is reset. The Z bit 
is set if the content of the register X is as a result of the opera- 
tion, otherwise it is reset. TAX is a single-byte instruction and 
its addressing mode is Implied. 

7.12 TXA - TRANSFER INDEX X TO ACCUMULATOR 

This instruction moves the value that is In the index register 
X to the accumulator A without disturbing the contents of the index 
register X. 

The symbolic notation is X A. 

TXA does not affect any register other than the accumula- 
tor and does not affect the carry or overflow flag. If the result in 
A has bit 7 on, then the N flag is set, otherwise it is reset. If the 
resultant value in the accumulator is 0, then the Z flag is set, other- 
wise it is reset- 

The addressing mode is Implied, it is a single-byte instruction. 
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7.13 TAY- TRANSFER ACCUMULATOR TO INDEX Y 

Tliis instruction moves the value of the accumulator into index 
register Y without affecting the accumulator. 
The symbolic notation is A -> Y. 

TAY infCruction only affects the Y register and does not affec 
either the carry or overflow flags. If the index register Y has bit 
then N is set, otherwise it is reset. If the content of the index re 
Y equals as a result of the operation, Z is set on, otherwise it is 

TAY is a single-byte instruction and the addressing mode is lir 

7.14 TYA - TRANSFER INDEX Y TO ACCUMULATOR 

This instruction moves the value that is in the index register 
to accumulator A without disturbing the contents of the register Y. 
The symbolic notation is Y > A. 

TYA does not affect any other register other than the accumula- 
tor and does not affect the carry or overflow flag. If the result ir 
the accumulator A has bit 7 on, the N flag is set. otherwise it is 
reset. If the resultant value in the accumulator A is 0, then the Z 
flag is set, otherwise it is reset. 

The addressing mode is Implied and it is a single-byte instruc- 
tion . 



Some of the applications of the transfer instructions between 
accumulator A and index registers X, Y are those when the user wishes 
to use the index register to access memory locations where there are 
multiple byte values between the addresses. in this application a 
count is loaded Into the index register, the index register is trans- 
ferred to the accumulator, a value such as 5, 7, 10, etc. is added 
immediate to tlie accumulator and results stored back into Che index 
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register using the TAX or TAY instruction. The consequence of this 
type of operation is that it allows the microprocessor to address 
non-consecutive locations in memory. Another application is where 
the internal transfer instructions allow the index registers to hold 
intermediate values for the accumulator which allows rapid transfer 
to and from the accumulator to help solve high speed data shuffling 
problems . 

7. 15 SUMMARY OF INDEX REGISTER APPLICATIONS AND MANIPULATIONS 

Primary use of index register X and Y is as offset and counters 
for data manipulation in which the index register is used to compute 
an address based on the value of the index register plus base address 
specified by the user, either in a fixed instruction format or in a 
variable pointer type format. In order to operate as both an offset 
and counter , index registers may be incremented or decremented by one 
or compared to values f rom memory . There are limi tat ions on the 
applications of each of the index registers which have to do with 
formats whicli are unique to certain instruction addressing modes . 
Because of the ability of the index registers to be loaded, changed 
and stored, they are also useful as general purpose registers. They 
can be used as interim storages for moves between memory locations 
or for moves between memory and the accumulator. 

One of the optimum uses of the indexing concept is the case 
when the index register is being used both as an offset and a counter. 
This type of operation makes use of the ability of tlie microprocessor 
to perform a decrement function on the index registers and set flags. 
Therefore, a s ingle decrement ins t rue t ion not only changes the value 
in the counter but can also perform a test on the count value. 
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CHAPTER 8 



STACK PROCBSSINC; 



SM INTRODUCTION TO STACK Am TO PUSH DOWN STACK CONCiHr 

In all of the discussions on addressing, it has been assumed that 
either the exact location or at least a relation to an exact location of a 
memory address was known. 

Although this is true in most of the pro^rarnmlng for control applica- 
tions, there are certain types of programming and applications which re- * 
quire the basic program not to be working with known memory locations but 
only with a known order for accessing memory. This type of programming is 
called "re-entrant coding" and it is often used in servicing interrupts. 

To implement this type of addressing, the microprocessor maintains a 
separate address generator which is used by the program to access memory. 
This address generator employs a push down stack concept. 

Discussions of push-down stacks are usually best stated considering 
that if one were given three cards — an ace, a king, and a ten — and 
were told that the order of cards was important, and were then asked to lay 
■f. them down on the table in the order in which they were given, ace first, 
the king on top of it and finally the ten, and then if they were retrieved 
one card at a time, the ten would be retrieved first even though it was 
put on last, the king would be retrieved second, and the ace would be 
retrieved last, even though it was put on first. 
I The only commands needed to implement this operation are "put next 

!' card on stack" and "pull next card from the stack." The stack could be 
^'processing clubs and then go to diamonds and back to clubs. However, we 
know that while we are processing clubs, we will always find the ten first, 
king second, etc. 
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The hardware implementation of the ordered card stack which was just 
described is a 8-bit counter, into which the address of a memory location 
is stored. This counter is called a "Stack Pointer." Every time data are 
to be pushed onto the stack, the stack pointer is put out on the address 
bus. data are written into the memory addressed by the stack pointer, and 
the stack pointer is decremented by 1 as may be seen in Example 8.1. 
Every time da-ta are pulled from the stack, the stack pointer is incremented 
by 1. The stack pointer is put out on the address bus, and data are read 
from the memory location addressed by the stack pointer. This implementa- 
tion using the stack pointer gives the effect of a push-down stack which 
is program-independent addressing. 

Example 8.1: Basic Stack Map for 3-Deep JMP to Subroutine Sequence 



Stack Address Data 

OlFF PCH 1 

OlFE PCL 1 

OlFD PCH 2 

OlFC PCL 2 

OlFB PCH 3 

OlFA PCL 3 
01F9 



In the above example, the stack pointer starts out at OlFF. The stack 
pointer is used to store the first state of the program counter by ptoring 
the content of program counter high at OlFF, and the content of program 
counter low at OlFE. The stack pointer would now be pointed at OlFD. The 
second time the store program count is performed, the program counter high 
number is stored on the stack at OlFD and the program counter low is stored 
at OlFC. The stack pointer would now be pointing at OlFB. The same pro- 
cedure is used to store the third program counter. 

Wlien data are taken from the stack, the PCL 3 will come first and the 
PCH 3 will come second just by adding 1 to the stack pointer before each 
memory read. The example above contains the program count for 3 successive 
jump and store operations where the jump transfers control to a subroutine 
and stores the value of the program counter onto the stack in order to re- j 
member to which address the program should return after completion of the | 
subrout ine . .1 
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Following is an example of a program that would create the Example 8.1 
stack operation. 

Example 8.2 : Basic Stack Operation 
Program 



Counter Label 



Instruction 



PCI 



Jump to Subroutine 1 



SUB I 



FC2 



Jump to Subroutine 2 



SUB2 



PC3 



Jump to Subroutine 3 



SUB3 



This is known as subroutine nesting "and is often encountered in solv- 
ing complex control equations. 

To correctly use the stack for this type of operation requires a jump 
to subroutine and ta return from subroutine instruction. 

8.1 JSR - JUMP TO SUBROUTINE 

This instruction transfers control of the program counter to a sub- 
routine location but leaves a return pointer on the stack to allow the 
user to return to perform the next instruction in the main program after 
the subroutine is complete. To accomplish this, the JSR instruction stores 
the program counter address, which points to the last byte of the jump 
instruction, onto the stack using the stack pointer. The stack byte contains 
the program count high first, followed by program count low. The JSR then 
transfers the addresses following the jump instruction to the program 
counter low and the program counter high, thereby directing the program 
to begin at that new address. 

The symbolic notation for this is PC + 2+, (PC + 1) PCL, 
(PC + 2) -»• PCH. 

The JSR instruction affects no flags, causes the stack pointer to be 
decremented by 2 and substitutes new values into the program counter low 
and the program counter high. The addressing mode for the JSR is always 
Absolute , 

Example 8.3 gives the details of a JSR instruction. 

Example 8.3 : Illustration of JSR Instruction 

Program Memory 
PC Data 

0100 JSR 

0101 ADL 

0102 ADH Subroutine 

Stack Memory 

Stack 
Pointer Stack 

OlFF 01 
OIFE 02 
OlFD 
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Cycle 
1 



Address Bus 
0100 

0101 

OlFF 
OlFF 

OIFE 

0102 

ADH, ADL 



Data Bus 
OP CODE 



New ADL 



PCH 



PCL 



ADH 



New 

OP CODE 

* S denotes "Stack Pointer." 



External 
Operations 

Fetch 

Instruction 



Fetch 
New ADL 



Store PCH 



Store PCL 



Fetch ADH 



Fetch New 
OP CODE 



Internal 
Operations 

Finish Previous 
Operation; Incre- 
ment PC to 0101 

Decode JSR; 
Increment PC to 0102 

Store ADL 

Hold ADL, Decre- 
ment S* to OIFE 

Hold ADL, Decre- 
ment S* to OlFD 

Store Stack Pointer 

ADL -> PCL 
ADH -> PCH 



In this example, it can be seen that during the first cycle the micro- 
processor fetches the JSR instruction. During the second cycle, address 
low for new program counter low is fetched. At the end of cycle 2, the 
microprocessor has decoded the JSR Instruction and holds the address low 
in the microprocessor until the stack operations are complete. NOTE: The 
stack is always stored in Page 1 (Hex address OlOO-OlFF) . 

The operation of the stack in the R6500-series microprocessors is such 
that the stack pointer is always pointing at the next memory location 
into which data can be stored. In Example 8.3, the stack pointer is assumed 
to be at OlFF in the beginning and PC at location 0100. During the third 
cycle, the microprocessor puts the stack pointer onto the address lines and 
on the fourth writes the contents of the current value of the program counter 
high, 01, into the memory location indicated by the stack pointer address. 
During the time that the write is being accomplished, the stack pointer is 
being automatically decremented by 1 to OIFE. During the fifth cycle, the 
PCL is stored in the next memory location with the stack pointer being auto- 
matically decremented. 
\ It should be noted that the program counter low, which is now stored 

\ in the stack, is pointing at the last address in the JSR sequence. This 
is not what would be expected as a result of a JSR instruction. It would 
be expected that the stack points at the next instruction. This apparent 
anomaly in the machine is corrected during the Return from Subroutine in- 
struction . 
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NOTE: AC tlie end of the JSR instruction, the values on the stack con- 
tain the program counter low and the program counter high wliich referenced 
the last address of the JSR instruction. Any subroutine calls wliich want 
to use the program counter as an intermediate pointer must consider this 
fact. It should be noted also that the Return from Subroutine instruction 
performs an automatic increment at tlie end of tlie RTS which means that any 
program counters which are substituted on the stack must be 1 byte or 1 
pointer count less than tlie program count to which the programmer expects 
the RTS to return. 

The advantage of delaying the accessing of the address high until 
after the current program counter can be written in the stack is that only 
the address low has to be stored in Che microprocessor. This has tlie 
effect of shortening tlie JSR instruction by one byte and also minimizing in- 
ternal storage requirements. 

After both program counter low and high have been transferred to the 
stack, Che program counter is used to access the next byte which is the ad- 
dress high for the JSR. During this operation, the s ixtli cycle, internally 
the microprocessor is storing the stack pointer wliich is now pointing at 
OlFD or the next location at which memory can be loaded. 

During the seventli cycle, the address high from the data bus and the 

address low stored in the microprocessor are transferred to tlie new program 
t 

counter and are used to access the next OP CODE, thus making JSR a 6-cycle 
instruction. 

At the completion of the subroutine Che programmer wants to return to 
the instruction following the Jump-to-Subrout ine instruction. This is 
accomplished by transferring the last 2 stack bytes to the program counter 
which allows the microprocessor to resume operations at the instruction fol 
lowing Che JSR, and it is done by means of the RTS instruction. 

8.2 RTS - RETURN FROM SUBROUTINE 

This instruction loads the program count low and program count high 
from the stack into die program counter and increments the program counter 
so that it points to the instruction following the JSR. The stack pointer 
is adjusted by incrementing It twice. 

The symbolic notation for the RTS is PCI, INC PC. 
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The RTS instruction does not affect any flags and affects only PCL 
and PCH. RTS is a single-byCe instruction and its addressing mode is Im- 
plied. 

The following Example 8,4 gives the details of the RTS instruction. 
It is the complete reverse of the JSR shown in Example 8.3. 

Example 8. A : Illustration of RTS Instruction 

Program Memory 
PC Data 

0300 RTS 

0301 ? 



Stack Memory 

Stack Pointer Stack 

OlFF 01 
01 EE 02 
OlFD ? 



Return from Subroutine (Example) 



Cycle 
1 

2 

3 

4 

5 
6 



Address Bus 
O30O 



0301 



OlFD 



OlFE 



OlFF 
0102 



0103 



Data Bus 
OP CODE 

Discarded 
Data 

Discarded 
Data 

02 
01 

Discarded 
Data 

Next 
OP CODE 



External 
Operat ions 

Fetch 
OP CODE 

Fetch Dis- 
carded Data 

Fetch Dis- 
carded Data 

Fetch PCL 

Fetch PCH 
Put OuC PC 

FeCch Next 
OP CODE 



Internal 
Operat ions 

Finish Previous 
Operation, 0301 ^ PC 

Decode RTS 

IncremenC Stack 
Pointer Co OlFE 

Increment S tack 
Pointer to OlFF 



Increment PC by 1 
to 0103 
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As we can see, the RT3 instruction effectively unwinds what was done 
to the stack in the JSR instruction. Because RTS is a single-byte instruc- 
tion it wastes the second memory access in doing a look-ahead operation. 
During the second cycle, the value located at the next program address 
after the RTS is read but not used in this operation. It should be 
noted that the stack is always left pointing at the next empty location, 
which means that to pull off the stack, the microprocessor has to wait 1 
cycle while it adds 1 to the stack address. This is done to shorten the 
interrupt sequence which will be discussed below; therefore, cycle 3 is a 
dead cycle in which the microprocessor fetches but does not use the current 
value of the stack and. like the fetch of address low on Indexed and Zero 
Page Indexed operations, does nothing other than initialize the micro- 
processor to the proper state. It can be seen that the stack pointer de- 
crements as data is pushed on to the stack and increments as data is 
pulled from the stack. In the fourth cycle of the RTS, the microprocessor 
puts out the OlFE address and reads the data stored there which is the pro- 
gram count low which was written in the second write cycle of the JSR. 
During the fifth cycle, the microprocessor puts out the incremented stack 
picking up the program count high which was written in the first write cyclt 
of the JSR. 

As is indicated during the discussions of JSR, the program counter 
stored on the stack really points to the last address of the JSR instruc- 
tion itself; therefore, during the sixth cycle the RTS causes the program 
count from the stack to be incremented. That is the only purpose of the 
sixth cycle. Finally, in the seventh cycle, the incremented program counter 
is used to fetch the next instruction; therefore, RTS takes six cycles. 

Because every subroutine requires one JSR followed by one RTS, the time 
to jump to and return from a subroutine is 12 cycles. 

In the previous two examples, we have shown the operations of the JSR 
located in location 100 and the RTS located in location 300. The follow- J 
ing pictorial diagram. Example 8.5, illustrates how the memory map for 
this operation might look: 
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Example 8.5 : Memory Map for RTS Instruction 



Address 

Bus Data 

100 JSR 

101 OA —I 

102 02 — f 

103 Next Instruction 



0204 



First Instruction of Subroutine- 



\ 0300 RTS 

With this capability of subroutining, the microprocessor is allowed to 
go from the main program to 1 subroutine, to the second subroutine, to a 
third subroutine, and then finally to work its way back to the main pro- 
gram. Example 8.6 is an expansion of Example 8.2 with the returns 
included. 

Example 8.6 : Expansion of RTS Memory Map 
Main Program 



JSR SUBl 





^ Next Inst. 








SUBl 






Stack 


Located at 








OlFF, 


OlFE 




Test a Value 









JSR SUB2- 



SUB2 



RTS 



JSR SUB3- 



SUB3 



RTS 



Stack Located at 
OlFD, OlFC 



Stack Located at 
OlFB, OlFA 
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This concept Is known as nesting of subroutines, and the number of 
subroutines which can be called in such a manner is limited only by the 
length of the stack. 

8.3 IMPLEMENTATION OF STACK 

As we have seen, the primary requirement for the stick is that irre- 
spective of where or when a stack operation is called, the microprocessor 
must have an independent counter or register which contains the current 
memory location value of the stack address. This register is called the 
Stack Pointer, S. The stack becomes an auxiliary field in memory which 
is basically independent of programmer control. We will discuss later how 
the stack pointer becomes initialized, but once it Is initialized, the pri- 
mary requirement is that it be self-adjusted. In other words, operations 
which put data on the stack cause the pointer to be decremented automati- 
cally; operations which take data off the stack cause the pointer to 
be incremented automatically. Only under rare circumstances should the 
programmer f ind it necessary to move his stack from one location to another 
if he is using the stack as designed. 

On this basis, there is no need for a stack to be longer than 256 bytes 
To perform a single subroutine call takes only two bytes of stack memory. 
To perform an interrupt takes only three bytes of stack memory. Therefore, 
with 256 bytes, one can access 128 subroutines deep or Interrupt 85 times. 
Therefore the length of the stack is extremely unlikely to be limiting. 
Microprocessors in the R6500 series have a 256-byte stack length. 

Figure 8.1, which is now the complete block diagram, shows all of the 
microprocessor registers. The 8-bit stack pointer register, S, has been 
added. It is initialized by the programmer and thereafter automatically 
increments or decrements , depend ing on whether data is being put on the 
stack or taken off the stack by the microprocessor under control of the 
program or the Interrupt lines. 
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STACK 
POINTER 



n i\ w 



IT 



Partial Block Diagram of a R6500 Microcomputer Sywtem Microprocessor hicludinji Stack Pointer, S 

FIGURES.! 



The primary purpose of the stack is to furnish a block of memory loca- 
tions in which the microprocessor can write data such as the program coun- 
ter for use in later processing. In many control systems the requirements 
for read/write memory are very small and the stack just represents another 
■demand on read/write mem.ory . Therefore for these applications it is preferable 
; for the stack to be in the Page Zero location in order that memory allocation 
; for the stack, the Zero Page operations, and the indirect addresses can be 
performed. Therefore, one of the requirements of a stack is that it be 
easily locatable into Page Zero. 

On the other hand, if more than one page of RAM is needed because of the 
r anjount of data that must be handled by the user programs, having the stack 
;:in Page Zero is an unnecessary waste of Page Zero memory in the sense that 
the stack can take no real advantage of being located in Zero Page, whereas 
•Other operations can. 
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In each of the examples, the stack has been located at high-order 
address 01 followed by a low-order address. In the same manner that the 
microprocessor forces locations 00 onto the high-order 8 bits of the 
address lines for Zero Page operations, the microprocessor automatically 
puts 01 Hex onto the high-order 8-bit address lines during each stack 
operation. This has the advantage to the user of locating the stack into 
Page One of memory which would be the next memory location added if the 
Zero Page operation requirements exceed Page Zero memory capacity. This 
has the advantafSie of the stack not requiring memory to be added specifi- 
cally for the stack but only requiring the allocation of existing memory 
locations. It should be noted that the selected addressing concepts of 
the R650O-series microprocessor support devices would involve connecting the 
memories such that bit 8, which is the selection bit for the Page One 
versus Page Zero, is a "don't care" for operations in which the user does 
not need more than one page of Read/Write memory. This gives the user the 
effect of locating the stack in Page Zero for those applications. 

The second feature that should be noted from the examples is that 
the stack was located at the end of Page One and decremented from that 
point towards the beginning of the page. This is the natural operation of 
the stack. RAM memory comes in discrete increments (6^, 128, 256),bytes so 
the normal method of allocating stack addressing is for the user to calcu- 
late the number of bytes probably needed for stack access. This could be 
done by analyzing the number of subroutines which might be called and the 
amount of data which might be put onto the stack in order to communicate 
between subroutines, or the number of interrupts plus subroutines which 
might occur with the respective data that would be stored on the stack for 
each of them. By counting three bytes for each interrupt, two bytes for 
each jump to subroutine, plus one byte for each programmer-controlled stack 
operation, the microprocessor designer can estimate the amount of memory 
which must be allocated for the stack. This is part of his decision-making 
process in deciding how much memory is necessary for his whole program. . 

Once the allocation has been made, it is recommended that the user 
assign his working storage from the beginning of memory forward and always 
load his stack at the end of either Page Zero, Page One, or at the end of J 
his physical memory which is located in one of those locations. This will | 
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give the effect of having the highest bytes of memory allocated to the 
stack, with lower bytes of memory allocated to user working storage; hope- 
fully, the two will never overlap. 

It should be noted that the natural operation of the stack, which often 
is called by hardware not totally under program control, is such that it 
will continue to decrement throughout the page to which it is allocated irre- 
spective of the user's desire to have it do so. A normal mistake in allo- 
cation of memory can result in the user's writing data into a memory location 
and later accessing it with another subroutine or another part of his pro- 
gram, only to find that the stack has very carefully written over that area 
as the result of its performing hardware control operations. This is one 
of the more difficult problems to diagnose. If this problem is suspected 
by the programmer, he should analyze memory locations higher than unex- 
plained disturbed locations. 

There is a distinctive pattern for stack operations which are unique 
to the user's program but which are quite predictable. An analysis of the 
value which has been destroyed will often indicate that it is part of an 
address which would normally be expected during the execution of the pro- 
gram between the time data were stored and the time they were fetched. This is 
a very strong indication of the fact that the stack somehow or other did get 
into the user's program area. This is almost always caused by improper con- 
trol of interrupt lines or unexpected operations of interrupt or subroutine 
calls and has only two solutions: (1) If the operation is normal and predict- 
able, the user must assign more memory to his program and particularly re- 
. assign his memory such that the stack has more room to operate; or (2) if 
the operation of the interrupt lines is not predictable, attention must be 
given to solving the hardware problem that causes this type of unpredictable 
r operation . 



8.3.1 Summary of Stack Implementation 

The R6500 series microprocessors have a single 8-blt stack 
register. This register is automatically incremented and decre- 
mented under control of the microprocessor to perform stack manipula- 
tion operations, under direction of the user program or the interrupt 
lines. Once the programmer has initialized the stack pointer to the 
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end of whatever memory he wants the stack to operate in, the program- 
mer can ignore stack addressing other than in those cases where there 
is an interference between stack operations and his normal program 
working space. 

In the R6500 series, the stack Is automatically located 
in Page One. The microprocessor always puts out the address 
0100 plus stack register for every stack operation. By selected mem- 
ory techniques, the user can either locate the stack in Page Zero or 
Page One, depending on whether or not Page One exists for his hard- 
ware . 



8.4 USE OF Wt STACK BY THi; PROGRAMMER 

Discussed in Section 8.1 was the use of the JSR to call a subroutine. 
However, not indicated was the technique by which the subroutine knew 
which data to operate on. There are three classical techniques for communi- 
cating data between subroutines. The first and most straightforward tech- 
nique is that each subroutine has a defined set of working registers located 
in Page Zero in which the user has left values to be operated on by the 
subroutine. The registers can either contain the values directly or can 
contain indirect pointers to values which would be operated on. The 
following example shows the combination of these: 

Example 8.7 : Call-a-Move Subroutine UsinR Preassigned Memory Locations 



Main Line Routine 



Location 10 
Location 11, 12 
Location 13, 14 



Count 

Base from Addresi 
Base to Address 



No. of. 



Bytes ' 


Ins 


t ruction 


2 


LDA 


/fCount -1 


2 


STA 


10 


2 


LDA 


//FRADH 


2 


STA 


12 


2 


LDA 


// FRADL 


2 


STA 


11 


2 


LDA 


//TOADL 


2 


STA 


13 


2 


LDA 


//TOADH 


2 


STA 


14 


_3 


JSR 


SUBl 


23 bytes 
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Comment 

Load Fixed Value for the Move ! 
Set up "FROM" Pointer 

Set up "TO" Pointer 



Subroutine Coding 



No. of 



Bytes Label Instruction 

2 SUBl LDY 10 

2 LOOP LDA (11) , Y 

2 STA (13), Y 

1 DEY 

2 BNE LOOP 
1 RTS 



Total 33 Bytes 

As has been previously discussed, the loop time is the overriding con- 
sideration rather than setup time for a large number of executions. 

It can be seen that we have used the techniques developed In previous 
sections of the indirect referencing, the jump to subroutine and the return 
from subroutine to perform this type of subroutine value communication. 
In this operation, there was no use of the stack except for the program 
counter value. 

A second form of communication is the use of the stack itself as an 
intermediate storage for data which are going to be communicated to the 
subroutine. In order for the programmer to use the stack as an in termed iate 
storage, he needs instructions which allow him to put data on the stack and 
to read from the stack. Such instructions are known as "push" and "pull" in" 
structions . 

8.5 PHA - PUSH ACCUMULATOR ON STACK 

This instruction transfers the current value of the accumulator to 
the next location on the stack, automatically decrementing the stack to 
point to the next empty location. 

The symbolic notation for this operation is A i . It should be remem- 
bered that the notation 4- means push to the stack, while t means pull from 
the stack. 

The Push A instruction affects only the stack pointer register which 
is decremented by 1 as a result of the operation. It affects no flags. 

PHA is a single-byte instruction and its addressing mode is Implied. 

The following example shows the operations which occur during Push A 
instruction . 
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Example R . 3 : (Operation of I'tlA, Assuming Stack at UlI'F 

External Internal 
Address Bus Data B us Op e rati o n s Operations 



Cycles 
1 



0100 

0101 

OlFF 
0101 



OP CODE 



Next 
OP CODE 

(A) 

Next 
OP CODE 



Operations 
Fetch 

Instruction 

Fetch Next 
OP CODE 
and Discard 

Write A on 
Stack 

Fetch Next 
OP CODE 



Finish Previous 
Operation , Incre- 
ment PC to 0101 

Interpret PltA In- 
struction, Hold 
P-Counter 

Decrement Stack 
Pointer to OlFE 



As can be seen, the PHA requires three cycles and takes advantage of the 
fact that the stack pointer is pointing to the correct location to write 
the value of A. As a result of this operation, the stack pointer will be 
-setting at OlFE. The notation (A) implies contents of A. Now that the 
data are on the stack, later on in the program the programmer will call for 
the data to be retrieved from the stack with a FLA instruction. 



8.6 PLA - PVLL ACCUMULATOR FROM STACK 

This instruction adds 1 to the current value of the stack pointer and 
uses it to address the stack and loads the contents of the stack into the 
A register. 

The symbolic notation for this is A+ . 

The PLA instruction does not affect the carry or overflow flags. It 
sets N if the bit 7 is on in accumulator A as a result of the instruction, 
otherwise it is reset. If accumulator A is zero as a result of Xhe PLA, 
then the Z flag is set, otherwise it is reset. The PLA instruction changes 
the contents of accumulator A to the contents of the memory location at 
stack register plus 1 and also increments the stack register. 

The PLA instrucf:ion is a single-byte instruction and the addressing 
mode is Implied . 

In the following example, the data stored on the stack in Example 8.8 
are transferred to the accumulator. 
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Example 8,9 : Up eratiun of PLA stack f ro m Examj ) le 8 .8 



Cycles 
1 



Address Bus Data Bus 



0200 



0201 



OlFE 



OlFF 
0201 



PLA 



Next 
OP CODE 



Discarded 
Data 

Data 

Next 
OP CODE 



External 
Operations 

Fetch 

Instruction 

Fetcli Next 
OP CODE and 
Discard 

Read Stack 

Fetch Data 

Fetch Next 
OP CODE 



Internal 
Operations 

Finish Previous Opera- 
tion, Increment PC to 
201 

interpret 1 ns true t ion , 
Hold P-Counter 

Increment Stack Pointer 
to OlFF 

Save Stack 

Data ^ A 



When data are being taken off tlie stack, there is one extra cycle during 
which time the current contents of the stack register are accessed but not 
used and the stack pointer is incremented by L to allow access to the value 
that was previously stored on tlie stack. The stack pointer is left point- 
ing at this location because it is now considered to he an empty location 
to be used by the stack during a subsequetit operation. 



8J usf-: oriusuhs and pulls to commlinica tl: variahlls wtwlln suhroutiaf 

Ori-RA TiONS 

In Example 8.10, we perform the same operation as we did in Example 8.7, 
except that here, instead of using fixed locations to pick up the pointers, 
we use the stack as a coimnunications vehicle ; 



Example 8.10 : Call-a-Move Subroutine Using tlie Stack to Comniunicate 



Main Line Routine 



Location 11, 12 
Location 13, lA 



Base 
Base 



"FROM" Address 
''TO" Address 



2 
1 
2 
I 

2 
1 

2 
1. 
2 
1 

_3 
18 



Ins true t ion 

LDA //Count -1 
PHA 

LDA //FRADL 
PHA 

LDA //FRADH 
PHA 

LDA //TOADL 
PHA 

LDA //TOADH 
PHA 

JSR SIMM 
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Revised 2/79 



Subroutine 



Bytes 


Label 


Instruction 


Comments 


2 


SUBl 


LDX 






1 


LOOPl 


FLA 






2 




STA 


10 X 




1 




DEX 




Move Stack to Memory 


2 




BNE 


LOOP 1 




1 




PLA 




Set up Count 


1 




TAY 






2 


LOOP 2 


LDA 


(11), Y 




2 




STA 


(13) .Y 


Move Memory Location 


1 




DEY 






2 




BNE 


LOOP 2 




2 




LDA 


15 




1 




PHA 




Restore PC to Stack 


2 




LDA 


16 


1 




PHA 






1 




RTS 







Total 42 Bytes 

We can see from this example that using the stack as a communica- 
tion vehicle actually Increases the number of bytes in the subroutine and 
the total bytes overall. However, the only time on^ should be using sub- 
routines in this case is when the subroutine is fairly long and is used 
fairly frequently. This technique does reduce the number of bytes in 
the calling sequence. The calling sequence is normally repeated once for 
every time the instruction is called; therefore the use of the stack to 
communicate should result in a net reduction in the number of bytes used 
in the total program. 

Up until this time, we have been considering that the stack is at a 
fixed location and that all stack references use the stack pointer. It 
has not been explained how the stack pointer in the microprocessor gets 
loaded and accessed. This is done through communication between^ the sta( 
pointer and index register X. 

8.8 TXS TRANSFER INDEX X TO STACK POINTER 

This instruction transfers the value in the index register X to the 
stack pointer. 

Symbolic notation is X S. 

TXS changes only the stack pointer, making it equal to the content 
the index register X. It does not affect any of the flags. 



t 
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TXS is a single-byte instruction and its addressing mode is Implied. 

Another application for TXS is the concept of passing parameters to 
the subroutine by storing them immediately after the jump to subroutine 
instruction. 

In Example 8.H, the from and to address, plus the count of number of 
values would be written right after the JSR instruction and its address. 

By locating the stack in Page Zero, the address of the last byte of 
the JSR can be incremented to point at the parameter bytes and then used 
as an Indirect pointer to move the parameter to its memory location. 

The key to this approach is transferring the stack pointer to X, which 
allows the program to operate directly on the address while it is in the 
stack. 

It should be noted that this approach automatically leaves the address 
on the stack, positioned so that the RTS picks up the next OP CODE address. 

Example 8.11 : Jump to Subroutine (JSR) Followed by Parameters 

Address Bus Data 

0100 JSR 

0101 ADL 

0102 ADH 

0103 To High 

0104 To Low 

0105 From High 

0106 From Low 

0107 Count 

0108 Next OP CODE 

Before concluding this discussion on subroutines and parameter passing, 
it should again be noted that the use of subroutines should be limited to 
those cases where the user expects to duplicate code of significant length 
several times in the program. In these cases, and only in these cases, is 
subroutine call warranted rather than the normal mode of knowing the 
addresses and specifying them in an instruction. In all cases where timing 
is of significant interest, subroutines should also be avoided. Subroutines 
add significantly to the setup and execution time of problem solution. How- 
ever, subroutines definitely have their place in microcomputer code, and 
three alternatives have been presented for use in application programs. 
The user will find a combination of the above techniques most valuable for 
solving his particular problem. 



8-19 



8.9 TSX - TRANSFER STACK POINTER TO INDEX X 

This instruction transfers the value in the stack pointer to the 
index register X. 

Symbolic notation is S X. 

TSX does not affect the carry or overflow flags. It sets N if 
bit 7 is on in index X as a result of the instruction, otherwise it is 
reset. If index X is zero as a result of the TSX, the Z flag is set, other- 
wise it is reset. TSX changes the value of index X, making it equal to 
the content of the stack pointer. 

TSX is a single-byte instruction and the addressing mode is Implied. 

8. 10 SA VING or THE PROCESSOR STATUS REGISTER 

During the interrupt sequences, the current contents of the processor 
status register (P) are saved on the stack automatically. However, there 
are times in a program where the current contents of the P register must 
be saved for performing some type of other operation. A particular example 
of this would be the case of a subroutine which is called independently and 
which involves decimal arithmetic. It is important that the programmer 
keeps track of the arithmetic mode tlie program is in at all times. One way 
to do this is to establish the convention that the machine will always be 
in binary or decimal mode, with every subroutine changing its mode being 
responsible for restoring it back to the known state. Tliis is a superior 
convention to the one that is about to be described, 

A more general convention would be one in which the subroutine that 
wanted to change modes of opera t ion wou Id push P onto the stack, then set 
the decimal mode to perform the subroutine and tlien pull P back from the 
stack prior to returning- f rom the subroutine. 

Instructions which allow the user to accomplish this are described 
in Section 8.11 and 8.12. 

8.n PHP - PUSH PROCESSOR STATUS ON STACK 

This instruction transfers the contents of the processor status reg- 
ister unchanged to the stack, as governed by the stack pointer. 
Symbolic notation for this is P+. 

The PHP instruction affects no registers or flags in the micropro- 
cessor . 

PHP is a single-byte instruction and the addressing mode is Implied. 
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8,12 PLP - PULE PROCESSOR STATUS FROM STACK 

This instruction transfers the next value on the stack to the Proces- 
sor Status register, thereby changing all of the flags and setting the mode 
switches to the values from the stack. 

Symbolic notation is Ft. 

The PLP instruction affects no registers in the processor other than 
the status register. This instruction could affect all flags in the status 
register. 

PLP is a single-byte Instruction and the addressing mode is Implied. 

8.JJ SUMMARYOl THE STACK 

The stack in the R6500 family is a push-down stack implemented 
by a processor register called the stack pointer which the programmer ini- 
tializes by means of a Load X immediately followed by a TXS instruction and 
thereafter is controlled by the microprocessor which loads data into mem- 
ory based on an address constructed by adding the contents of the stack 
pointer to a fixed address. Hex address 0100. Every time the microproces- 
sor loads data into memory using the stack pointer, it automatically decre- 
ments the stack pointer, thereby leaving the stack pointer pointing at the 
next open memory byte. Every time the microprocessor accesses data from 
the stack, it adds 1 to the current value of the stack pointer and reads 
the memory location by putting out the address 0100 plus the stack pointer. 
The status register is automatically pointing at the next memory location 
to which data can now be written. The stack makes an Interesting place to 
store Interim data without the programmer having to worry about the actual 
memory location In which data will be directly stored. 

There are 8 instructions which affect the stack. They are: BRK, 
JSR, PHA, PHP, PLA, PLP, RTI , and RTS . 

BRK and RTI involve the handling of the interrupts. 
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CHAPTER 9 

RESET AND INTERRUPT CONSIDERATIONS 



9.0 VECTORS 

Before developing the concepts of how the R650O-series microprocessors 
handle interrupts and start-up, a brief definition of the concept of vector 
pointers should be developed. 

In fhe sections on Jumps and Branches. It was always assumed that 
the program counter Is changed by the microprocessor under control of the 
programmer while accessing addresses which were in program sequence. In 
order to get the microprocessor started and In order to properly handle 
external control or interrupt, there has been developed a different way 
of setting the program counter to point at a specific location. This 
concept is called vectored pointers. A vector pointer consists of a pro- 
gram counter high and program counter low value which, under control of 
the microprocessor, is loaded in the program counter when certain external 
events occur. The word vector is developed from the fact that the micro- 
processor directly controls the memory location from which a particular 
operation will fetch the program counter value and hence the concept of 
vector . 

By allowing the programmer to specify the vector address and then by 
allowing the programmer to write coding that the address points to, the 
microprocessor makes available to the progranuner all of the control 
necessary to develop a general " purpose control program. The microprocessor 
has fixed addresses in memory from which it picks up the vectors. By this 
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implementation, minimum hardware in the microprocessor is required. 
Locations FFFA through FFFF are reserved for vector pointers for the 
microprocessor. Into these locations are stored the Interrupt vectors 
or pointers for non-maskable interrupt, reset, and interrupt request. 

9.1 RESET OR Ri:START 

In the microprocessor, there is a state counter which controls when 
the microprocessor is going to use the program counter to access memory 
to pick up an instruction; then, after the instruction is loaded, the 
microprocessor goes through a fixed sequence of interpreting instructions 
and develops a series of operations which are based on the OP CODE 
decoding . 

Up to this point, it has been assumed that the program counter was 
set at some location, and that all program counter changes are airected 
by Che program once the program counter had been initialized. 

Instructions exist for the initialization and loading of all other 
registers in the microprocessor except for the initial setting of the 
program counter. It is for this initial setting of the program counter 
to a fixed location in the restart vector location specified by tlie micrp- 
processor programmer that the reset line in the microprocessor is pri- 
marily used. 

The reset line is controlled during power on initialization and is 
a common line which is connected to all devices in the microcomputer sys- 
tem which have to be initialized to a known state. The initialisation of 
most I/O devices is such that they are brought up in a benign state so 
that with minimum coding in the microcomputer, the programmer can con- 
figure and control the I/O in an orderly fasliion. 

The concept has important implications in systems where damage can 
be done if peripheral devices came up in unknown states. Therefore, 
in the R6500, power on or reset control operates at two levels. 



First, by holding of an external line to ground, and having this external 
line connected to all the devices during power-up transient conditions, 
the pntire microcomputer system is initialized to a known disabled state. 
Second, the releases of the reset line from the ground or TTL zero 
condition to a TTL one condition causes the microprocessor to be automat- 
ically initialized, first by the internal hardware vector which causes it 
to be pointed to a known ptugram location, ana secondly through a software 
program which is written by the user to control the orderly start-up 
of the microcomputer system. 

All of the R6500 family parts also obey a discipline that while 
the reset line is low, the system is in a stop or reset state. The micro- 
processor is guaranteed to be in a Read state and upon release of the re- 
set line from ground to positive, the microprocessor will continue to 
hold the line in a Read state until it has addressed the specified vectored 
count location, at which time control of the microprocessor is available 
to the programmer . 

9.2 START FUNCTION 

While the reset line is in the low state, it can be assumed that 
Internal registers may be initialized to any random condition; therefore, 
no conditions about the internal state of the microprocessor are assumed 
other than that the microprocessor will, one cycle after the reset line 
goes high , implement the following sequence : 



t 



Example 9.1 : Illustration o£ Start Cycle 
Cycles A ddress Bus Data Bus External Operation Internal Operation 



? ? Don't Care Hold During Reset 

2 1 ? Don't Care First Start State 

3 0100 + SP ? Don't Care Second Start State 

4 0100 + SP-1 ? Don't Care Third Start State 

5 0100 + SP-2 ? Don't Care Fourth Start State 

6 FFFC Start PCL Fetch First Vector 

7 FFFD Start PCH Fetch Second Vector Hold PCL 

8 PCH PCL First Load First OP CODE 

OP CODE 



The start cycle actually takes seven cycles from the time the reset 
line is let go to TTL plus. On the eighth cycle, the vector fetched from 
the memory location FFFC and FFFD is used to access the next instruction. 
The microprocessor is now in a normal program load sequence, the location 
where the vector points should be the first OP CODE .which the programmer 
desires to perform. 

The second point that should be noted is that the microprocessor 
actually accesses the stack three times during the start sequence in 
cycles 3, 4 and 5. This is because tlie start sequence is in effect a 
specialized form of interrupt with the exception that the read/write line 
is disabled so that no writes to stack are accomplished during any of the 
cycles . 

9.3 PROGRAMMER CONSIDI- RATIONS FOR iNlTlAUZATlON SEQUliNO-S 

There are two major facts to remember about initialization. First, the 
only automatic operations of the microprocessor during reset are to turn 
on the interrupt disable bit and to force the program counter to the vector 
location specified in locations FFFC and FFFD and to load the first instruc- 
tion from that location. Tlierefore, the first operation in any normal pro- 
gram will be to initialize the stack. This should be done by liaving pre- 
viously decided wliat the stack value sliould be for initial operations and 
then doing a LDX immediate of this value followed by a TXS. By this simple 
operation, the microprocessor is ready for any interrupt or non-maskable 
interrupt operation which might occur during the rest of the start-up 
sequence . 
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Once this is accomplished, the two nonvarlable operations of the 
machine are under control. The program counter is initialized and under 
program control, and the stack is initialized and under program control. 
The next operations during the initialization sequences will consist of 
configuring and setting up the various control functions necessary to 
perform the I/O desired for the microprocessor. 

Specific discussion for considerations regarding the start-up are 
covered in Section 11. 

The major things which have to be considered include the current 
state of the I/O device and the nondestructive operations that will 
allow the state to be changed to the active state. 

The initialization programs mostly consist of loading accumulator 
A Immediately with a bit pattern and storing it in the data control regis 
ter of an I/O device. 

NOTE : Tlie interrupt disable is automatically set by the micro- 
processor during the start sequence. This is to minimize 
the possibility of a series of interrupts occurring during 
the start-up sequence because of uncontrolled external 
values, although it is usually possible to control interrupts 
as part of the configuration. 
The programmer should consider two effects: 1) The non-maskable 
interrupt is not blockable by this technique since it would be possible 
to configure a device that was connected to a non-maskable interrupt 
and have to service the interrupt immediately; and 2) the mask must be 
cleared at the end of the start sequence unless the user has specific 
reason to inhibit interrupts after he has carried out the start-up 
sequence. Therefore, the next-to-last instruction of the start-up 
sequence should be CLI. 
g It should be noted that the start-up routine is a series of 

sequential operations which should occur only during power on initial- 
ri; Ization and is the first step in the programmed logic of the machine. 



Because Che execution of the routine during power on occurs very 
seldom in the normal operation of the machine, the coding for power 
on sequence should tend to minimize the use of memory space rather 
than speed. 

The last instruction in the start-up sequence should initialize 
the decimal mode flag to the normal setting for the program. 

The next instruction should be the beginning of the user's normal 
programming for his device, everything preceding that being known as 
"housekeeping." 

9.4 RESTART 

It should be noted that the basic microprocessor control philosophy 
allows for a single common reset line which initializes all devices. 
This line can be used to clear the microprocessor to a known state and to 
reset all peripherals to a known state; therefore, it can be used as a 
result of power interruption, during tlie power on sequence, or as an 
external clear by the user to re-initialize the system. 

As discussed in the hardware manual, restart is often used as an 
aid to making sure the microprocessor has been properly interconnected 
and that programs have been loaded in the correct locations. 

9.5 INTERRUPT CONSIDERATIONS 

Up until this point, the microprocessor has to proceed under program- 
mer control through a variety of sequences. The only way for the program- 
mer to change the sequence of operations of the microprocessor was to 
change the program counter location to point at new operations. The 
microprocessor is in control of fetching the next instruction at the 
conclusion of the current instruction. The only way that external events 
could control the microprocessor, if it were not for interrupts, would be 
for the programmer to periodically interrupt or stop processing data and 
check to see whether or not an external event which might cause him to 
change his direction has occurred. The problem with this technique is that 
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1/0 events are usually asynchronous, i.e., not timed with the micro- 
processor internal instructions; therefore, it would be possible for the 
event to occur shortly after the programmer has stopped to look at I/O 
events which would mean that the event would not be sampled until the 
programmer took the time to stop his coding and sample again. 

Because the sampling of I/O devices normally takes several byte 
counts or cycles to accomplish, the frequent insertion of checking 
routines into straight line code results in significant delays to the 
entire program. In frying to use this technique, there has to be a 
tradeoff between the fact that the program wastes a significant 
amount of time checking events which have not yet occurred versus 
delaying checking of an event which has occurred and if not timely 
serviced the data may be lost. 

In order to solve this dichotomy, Che concept of interrupt is utilized- 
to signal the microprocessor that an external event has occurred and the 
microprocessor should devote attention to it immediately. This technique 
accomplishes processing in which Che microprocessor's program is inCer- 
rupCed and the event that caused the interrupt is serviced. 

Transferring most of data and control to I/O devices in an interrupt 
driven environment will usually result in maximum program and/or program- 
mer efficiency. Each event is serviced when it occurs, which means that 
there is a minimum amount of delay in servicing events, also a minimum 
amount of coding because of elimination of the need to determine occurrence 
of several events simultaneously; each interrupting event is handled 
as a unique combination. It is possible to interrupt an Interrupt 
processing routine and, therefore, all the interrupt logic uses the 
stack which allows processing of successive interrupts without any 
penalty other than increasing the stack length. 

A real-world example of an event which should inCerrupt is when 
the user is given a panic buCCon indicating to the microcomputer' some 
event has occurred that requires total immediate attention of the 
j microprocessor to solving that problem. 
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The action and events are as follows: The microprocessor user 
pushes the panic button; the panic switch sensor causes an externa 
device to indicate to the microprocessor an interrupt Is desired 
microprocessor checls the status of the internal interrupt inhibit 
signal- if the internal inhibit is set. then the interrupt is ignored. 
However, if it is reset. or when it becomes reset through some program 
action, the following set of operations occur: 



Cycles 
1 



Example 9.2 : interrupt Sequence 

Data Bus FvfPrnal Operation 
OP CODE Fetch OP CODE 



Address Bus 

, PC 



3 

6 
7 



PC 

OlFF 

OlFE 

OlFD 

FFFE 
FFFF 

Vector 
PCH PCL 



OP CODE Fetch OP CODE 



PCH 
PCL 
P 

New PCL 
New PCH 

OP CODE 



Store PCH on Stack 

Store PCL on Stack 

Store P on Stack 

Fetch Vector Low 
Fetch Vector High 

Fetch Interrupt 
Program 



Internal Operation 

Hold Program Counter, 

Finish Previous 

Operation 

Force a BRK 
Instruction, Hold 
p-Counter 
Decrement Stack 
Pointer to OlFE 
Decrement Stack 
Pointer to OlFD 
Decrement Stack 
Pointer to OlFC 
Put Away Stack 
Vector Low 
PCL and Set I 
Increment PC to 
PC + 1 



AS can be seen in Example 9.2, the microprocessor uses the stack to 
save the reentrant or recovery code and then uses the interrupt vectors 
TpFE and PFEF. (or KKFA and FFFB) . depending on whether or not an interrupt 

e t or a ^-maskable interrupt request had occurred. it should be 
Tea that the interrupt disable is turned on automatically at th.s point 
by the microprocessor. 
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Because the Interrupt disable had to be off for an interrupt request 
to have been honored, the return from Interrupt which loads the processor 
status from before the interrupt occured has the effect of clearing the 
interrupt disable bit. After the interrupt has been acknowledged by the 
microprocessor by transferring to the proper vector location, there are a 
variety of operations which the user can perform to service the Interrupt; 
however, all operations should end with a single instruction which 
reinitializes the microprocessor back to the point at which the Interrupt 
occurred. This instruction is called the RTI instruction. 

9.6 RTI - RETURN FROM INTERRUPT 

This instruction transfers from the stack into the microprocessor 
the processor status and the program counter location for the instruction 
which was interrupted. By virtue of the interrupt having stored this data 
before executing the instruction, and due to the fact that the RTI reini- 
tializes the microprocessor to the same state as when it was interrupted, 
the combination of interrupt plus RTI allows truly reentrant coding. 

The symbolic notation for RTI is Ft PCt. 

The RTI instruction reinitializes all flags to the position to the 
point at which they were when the interrupt was taken, and sets the program 
counter back to its pre-interrupt state. It affects no other registers 
in the microprocessor. 

RTI is a single-byte Instruction and its addressing mode is Implied. 

In the following example, we can see the internal operation of the 
RTI which restores the microprocessor: 



Example 9.3 : Return from Interrupt 



Cycles 
1 

2 
3 

k 

5 

6 

7 



Address Bus 
O3O0 

0301 
OlFC 

OlFD 

OlFE 

OlFF 

[ 

PCH PCL 



Data Bus 
RTI 

? 
? 

P 
PCL 
PCH 



External Operation 
Fetch OP CODE 



Fetch Next OP CODE 
Discarded Stack 
Fetch 

Fetch P Register 



Fetch PCL 
Fetch PCH 



OP CODE Fetch OP CODE 



Internal Operation 

Finish Previous 
Operation , Increment 
PC to 0301 
Decode RTI 
Increment Stack 
Pointer to OlFD 
Increment Stack 
Pointer to OlFE 
Increment Stack Point 
er to OlFF. Hold PCL 
>H-PCL, Store 
Stack Pointer 
Increment New PC 



Note the effects of the extra cycle (3) necessary to read data from 
stack which causes the RTI to take six cycles. The RTI has restored the 
stack, program counter, and status register to the point at which they 
were before the interrupt was acknowledged. 

There is no automatic saving of any of the other registers in the 
microprocessor. Because the interrupt occurred to allow data to be trans- 
ferred using the microprocessor, the programmer must save the various in- 
ternal registers at the time the interrupt is taken and restore them prior 
to returning from the interrupt. Saving of the registers is best done 
on the stack as this allows as many consecutive interrupts as the program- 
ming will allow for. Therefore, the routines which save all registers 
and restore them are as follows: 

Example 9.4 : Illustration of Save and Restore for Interrupts 
Cycle Bytes 



3 


1 


SAVE 


PHA 


Save A 


2 


1 




TXA 


Save X 




1 




PHA 




2 


1 




TYA 


Save Y 


3 


1 




PHA 




13 


5 








A 


1 


RESTORE 


PLA 


Restore Y 


2 


1 




TAY 






1 




PLA 


Restore X 


2 


1 




TAX 




it 


1 




PLA 


Restore A 


16 


5 
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The SAVE coding assumes that the programmer wants to save and to 
restore registers A, X and Y. It should be noted that for many inter- 
rupts, the amount of coding that has to be performed in the interrupt is 
fairly small. 

In this type of operation, it is usually desirable to shorten the 
interrupt processing time and not to use all of the registers in the 
machine. A more normal interrupt processing routine would consist of 
saving only registers A and X, which means that the restore routine would 
be to restore only registers X and A. This has the effect of shortening 
the interrupt routine by two bytes, and also shortens the restore routine 
by two bytes, and will remove 5 cycles from the interrupt routine and 6 
cycles from the restore routine. 

This technique combined with automatic features of the interrupt 
and the KTI allows multiple Interrupts to occur with successive inter- 
rupts interrupting the current interrupt. This is one of tlie advantages 
of the stack — as many interrupts can interrupt other interrupts as can 
be held in the stack. The stack contains six bytes for every interrupt 
if all registers are saved, so 42 sequences of interrupts can be stored 
in one page. However, in more practical situations, consecutive inter- 
rupts hardly ever get more than about three-deep. 

The advantage of permltt ing an interrupt to interrupt an interrupt 
is that the whole concept behind the interrupt is to let asynchronous 
events be responded to as rapidly as possible; therefore, it is desirable 
to allow the servicing of one interrupt to be interrupted to service the 
second, as long as the first interrupt has been properly serviced. 

t 

i To review how this is accomplished with the normal interrupt 
capability of the R6500, it is important that we review the bus concept 
iwhich is inherent in the R6500 family and which is compatible with the 

[Meeoo . 

As has already been discussed, all I/O operations on this type of 
^microprocessor are accomplished by reading and writing registers which 
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actually represent connections to physical devices or to physical pins 
which connect to physical devices. 

Up to this point, this discussion has addressed itself to 
transferring of data into and out of the microprocessor. However, there 
is a concept* that is inherent in the bus discipline that says that when- 
ever an interrupt device capable of generating an interrupt desires to 
accomplish ah interrupt, it performs two acts; first, it sets a bit. 
usually bit 7 , in a register whose primary purpose is to communicate 
to the microprocessor the status, of the device. Tlie interrupting device 
causes one of perhaps many output lines to be brought J^w. These 
collector-ORM outputs are connected together to the IRQ pin on the 

R6500 microprocessor. 

The interrupt request to the R6500 is the IRQ pin being at a 
TTL zero. In order to minimize the handshaking necessary to accomplish 
an interrupt, all interrupting devices obey a rule that says that once an 
interrupt has been requested by setting the bit and pulling interrupt 
low, the interrupt will be held by the device until the condition that 
cauled the interrupt has been satisfied. This allows several devices 
to interrupt simultaneously and also allows the microprocessor to 
ignore an interrupt until it is ready to- service it. This ignoring is 
done by the interrupt disable bit which can be set by the programmer 
and is initialized on by the interrupt sequence or by the start sequence. 

Once the interrupt line is low and interrupt disable is off. the 
microprocessor takes an interrupt which sets the interrupt disable. 
The interrupt disable then keeps the low input line from causing more than 
one interrupt until an interrupt has been serviced, Tliere is no other 
handshaking between the microprocessor and the interrupting device other 
than the collector^R M line. This means that the microprocessor must use 
the normal addressing registers to determine which of several coUector- 
CR'd devices caused the line to go low and to process the interrupt which 
has been requested. 
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Once the processor has found the Interrupting device by means of 
analyzing status bits which indicates which interrupt has been requested, 
the microprocessor then clears the status by reading or writing data 
as indicated by the status register. 

It should be noted that a significant difference between status 
registers and data registers in I/O devices is that status registers 
are never cleared by being read, only by being written into — or by the 
microprocessor transferring data from a data register which corresponds 
to some status in the status register. Detailed examples of this 
interaction are discussed in Chapter 11. The clearing of the status 
register also releases the col lec tor-OR ' d ogt-put, thereby releasing tlie 
interrupt pin request. 

The basic interaction between the microprocessor and interrupting 
device is the interrupting device setting the status bit and brings its 
output IRQ line low. If its output IRQ line is connected to the micro- 
processor interrupt request line, the microprocessor waits until the 
interrupt disable is cleared, takes the interrupt vector, and sets the 
Interrupt disable which inhibits further interrupts for the IRQ line. 
The microprocessor determines which interrupting device is causing an 
Interrupt and transfers data from that device. 

4 Transferring of data clears the interrupt status and the IRQ pin. At 
this point, the programmer could decide that he was ready to accept another 
Interrupt, even though the data may have been read but not yet operated on. 
Allowing interrupts at this point gives the most efficient operation of 
Ithe microprocessor in most applications. 

There are also times when a programmer may be working on some coding 
whose timing is so important that he cannot afford to allow an interrupt 
to occur. During these times, he needs to be able to turn on the interrupt 
disable. To accomplish this, the microprocessor has a set or clear 
interrupt disable capability. 
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9. 7 SOJ-TWAHi- POiJ.m; l OH INTh'RRUrTCAUShS 

As was indicated above, any one of several devices are collec tor-OR 'd 
to cause an IRQ. The effect of any one of the devices or a combination of 
them having polled the IRQ line low is always the same. The interrupt 
stores the current status of the program counter and processor on the 
stack and transfers to a fixed vector address. In servicing the inter- 
rupt, it is important to save tliose registers which will be used in the 
analysis of the interrupt and during the interrupt processing, so the 
normal first steps of the interrupt routine are to do the SAVE pro- 
cedures . 

The next operation is to determine which of tlie various potential 
interrupting devices caused the interrupt. To accomplish this, the 
programmer should make use of the fact that all interrupting devices 
signal the interrupt by a bit in the status register. Ail currently 
Implemented 6800 and 6500 peripherals always have interrupt indicators; 
eitlicr bit 7 or bit 6 in their status register. Therefore, the basic loop 
that a user will use to verify the existence of an interrupt on one of 
five devices is as f ol lows : 

Example 9 . 5 : Interrupt Polling 

No. of Bytes Cycles 



3 






LDA 


Status 1 


2 


2 




BMl 


FIRST 


3 






LDA 


Status 2 


2 


2 




BMI 


SECOND 


3 


k 




LDA 


Status 3 


2 


2 




BMI 


THIRD 


3 


k 




LDA 


Status k 


2 


1 




BMI 


FOURTH 


3 






LDA 


Status 5 


2 


2 




BMI 


FIFTH 






RESl 


JMP 


to RESTORE 






FIRST 


LDA 


DATA L 








CM 










I'rocess 


1 








etc . 





In this example, the simplest case where the potential interrupts 
are indicated by bit 7 being on, has been assumed. This allows taking 
advantage of the free N-blt test by following the load of the first 
status register with a branch on result minus. If the first device has an 
active interrupt request, the BMI will be taken to* FIRST where the data Is 
transferred. This automatically clears the interrupt for the first device. 
To allow multiple interrupts, the load A is followed by the CLI instruction 
which allows the program "o accept another interrupt. As a result of the 
CLI, one of two things can occur; there Is not another interrupt currently 
active, in which case, the microprocessor will continue to process the 
first interrupt down to the point where the interrupt is complete and the 
first subroutine does a jump to RESTORE, which is the routine that restores 
the registers that were used in the process ot servicing the interrupt. 
If anotlier device has an active interrupt which occurred eitlier prior 
to the first interrupt or subsequent to it but before the microprocessor 
has reached the point where the CLI occurs, then the microprocessor will 
immediately interrupt again following the CLI, go back and save registers 
as defin?.d before and come back into the polling loop. Therefore, multiple 
interrupts are serviced in the order in which they are examined in the polling 
sequence. Polling means that the program is asking each device individu- 
ally whether or not it is the one that requested an interrupt. 

It should be noted that polling has the effect of giving perfect 
priority in the sense that no matter which two interrupts occur before the 
microprocessor gets to service one, the polling sequence always gives 
priority to the highest-priority device first, then the second-highest, then 
the third-highest, etc. In light of the fact that this polling sequence requires 
no additional hardware to implement other than is available in the inter- 
rupting devices themselves, this is the least expensive form of interrupt 
and the one thatshould be used whenever possible because of its indepen- 
dence from external hardware. 
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Although it would appear that the last Interrupting device in a 
sequence pays a significant time penalty based on the amount of instruc- 
tions to be executed before the last device is serviced, the amount of 
time to perform polls is only six cycles per device and, therefore, 
the extra penalty that the last device has to pay over the first device 
is 24 cycles. This Is in comparison to a minimum time to cause an inter- 
rupt (8 cycles), plus store time for registers (in the range of 
another 8 to 13 cycles) which means that the delay to the last devices 
is roughly twice what it would be for the first device. 

This timing just described represents a most interesting part of the 
analysis of interrupts for a microprocessor. There is a certain 
amount of fixed overhead which must be paid for the interrupt. This over- 
head includes the fact that the interrupts can occur only at the end of 
an instruction. Therefore, if an interrupt occurs prior to the end of 
an instruction, the microprocessor delays until the end of the instruction 
to service it. Accordingly, in doing the worst-case analysis, one must 
consider the fact that the interrupt might be occurring in the middle of 
a seven-cycle, read/modify /wri te instruction, which means that the worst- 
case time to process the first instruction in an interrupt sequence is' 
14 cycles (7 cycles plus the 7 cycles for the interrupt). 

In light of the fact that saving of additional registers is often 
required (at least the accumulator A must be saved), at least twice 
the number of cycles will be required. Consequently, the absolute minimum t\ 
worst-case time for an interrupt is 17 cycles plus the time to transfer 
data which is another A cycles. Therefore, interrupt-driven systems must 
be capable of handling a delay of at least 20 cycles and, more realistically, 
of 20 to 50 cycles before the first interrupt is serviced. This means that 
devices which are running totally interrupt-driven must not require succes- 
sive bytes of data to be transferred to the microprocessor in less than 30 
or 40 cycles and, on a given system, only one device is capable of operating 
at that rate at one time. This limits the interrupt-<riven frequency of 
data transfer to 40 K bytes in a 1-MHz clock system, and 80 K bytes in the 
2-MHz clock system. 



Another consideration is the timing delay when low priority interrupt 
has just started to be serviced. The interrupt mask Is on. and higher 
priority interrupts are blocked from service. In this case, the delay 
to- the service can easily stretch out to 100 cycles before the interrupt 
mask is cleared. This is one of the reasons for clearing up the inter- 
rupt mask as soon as data are transferred. (The non-maskable interrupt 
which will be discussed later is a solution to this problem.) A second reason 
is to use interrupts only for systems that have adequate buffering and/or 
slower transfer rates. This does not imply that most microprocessor 
applications should not be primarily interrupt-driven. The R6500 inter- 
rupt system is designed to be very economical and easy to apply. It should 
be used for almost all control applications, other than when the throughput 
described is not sufficient to handle the particular problem. It should 
be remembered that at 1 MHz the R6500 microprocessors are not really capable 
of handling problems with more than 50 K bytes throughput for a sustained 
period of operation. It is also true that in most control applications, 
many of the signals occur at much slower rates or are buffered so that 
the allowable response time to a request for service is significantly longer 
than the 20 to 50 cycles that can normally be expected with a polling system. 
Because of this, it is expected that most applications will be quite 
satisfied by the polling technique desrlbed above. 



FULLY VECTORED INTERRUPTS 

M However, there are occasions where several high-speed peripherals 
||can be managed by the microprocessor if the user is willing to make the 
|^:,,investment to attain a truly vectored interrupt. A second level of 
" .Interrupt vectoring is possible by merely putting one high-priority device 
||on Che non-maskable interrupt line. However, in the case when multiple 
^inputs are desired with both priority encoding and true vectoring, the 
||R6500 microprocessors combined with appropriate hardware have the ability in 
^the first polling instruction to transfer control to appropriate Interrupting 
ice service software. 
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The R6500 microprocessors contain, In two bytes of memory, an Indirect 
pointer to the address of the subroutine in which resides the interrupt pro- 
cessing for the device which the priority encoder has selected. This gives 
an effective service time of approximately 24 cycles to a prioritized inter- 
rupt and is one of the primary applications of the jump indirect capability. 

9.8.1 JMP Indirect 

This instruction establishes a new value for the program counter. 

It affects only the program counter in the microprocessor and affects 
no flags in the status register. 

JMP Indirect is a 3-byte instruction. 

In the JMP Indirect instruction, the second and third bytes of the 
instruction represent the indirect low and high by tes, respec t ive ly. o f the 
memory location containing the effective ADL. Once ADL is fetched, the pro- 
gram counter is incremented with the next memory location containing ADH. 



Example 9.6 : Illustration of JHP Indirect 



Address 
Cyc le Bus 



Data 
Bus 



External Internal 
Operation Operation 



0100 



0101 



OP CODE Fetch OP CODE Finish Previous 

Operation. 
Increment PC to OlOfl 



lAL 



3 0102 lAH 

4 lAH. lAL ADL 

5 IA11,IA1.+ 1 ADH 



Fetch lAL 

Fetch lAH 
Fetch ADL 
Vvtih ADII 



Interpret Instruct! 
Increment PC to lOi 

Store lAL 

Add 1 to lAL 

Store ADh 



6 ADH. ADL Next OP Fetch Next 

t CODE OP CODE 



9.9 INTERRUPT SUMMARY 

There is an Interrupt request line (IRQ) which, when low, indicates 
one of the devices which are connected to the Interrupt request line 
requires service. At the beginning of the interrupt service routine, the 
user should save, on the stack, whatever registers will be used in his 
interrupt processing routine. His program then goes through a polling 
sequence to determine the Interrupting device by analyzing the status 
registers in the order of priority of service for the I/O devices. On 
finding a device which requires service, the data for that device should 
be read or written as soon as possible and the interrupt disable cleared 
80 that the microprocessor can again interrupt for servicing lower-priority 
devices. Devices with over AO K bytes transfer, etc., and mixed devices 
with over 20 K bytes should not normally be interrupt-driven. All others 
may be interrupt-driven as it minimizes the service time and programming 
for I/O operations. 

9.10 NON MASKABLE INTERRUPT 

As discussed, it is often desirable to have the ability to Interrupt 
an Interrupt with a high-priority device which cannot afford to wait during 
the time interrupts are disabled. For this reason, the R6500 microprocessors 
have a second interrupt line, called a Non-Maskable Interrupt. The input 
characteristics of this line are different than the Interrupt request line 
(IRQ) which senses it needs service when it remains low. The non-maskable 
.input is an edge-sensitive input — which means that when the collector-OR' d 
^input transitions from high to low, the microprocessor sets an Internal flag 
puch that at the beginning of the next instruction, no matter what the 
|.tatus of the interrupt disable, the microprocessor performs the interrupt 
sequence shown In Example 9.2, except that the vector pointer put out in 
I cycle 6 and 7 is FFFA and FFFB. 

This gives two effects of a non-maskable interrupt. First, no 
letter what the status of the interrupt disable, the non-maskabie inter- 
frupt will Interrupt at the beginning of the next instruction; therefore. 
|the maximum response time to the vector point is lA cycles. Secondly, the 
Ilnternal logic of the R6500 microprocessors are such that if an Interrupt 
^tquest and non-maskable Interrupt occur simultaneously, or If the non- 
ftaskable Interrupt occurs prior to the time that the vectors are selected. 
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the microprocessor always assigns highest priority to the non-maskable inter- 
rupt. Therefore, the FFFA and FFFB vector are always taken if both interrupt! 
are active at the time the vector is selected. Thus, the non-maskable inter- 
rupt is always a higher-priority fast-response line, and can, in any given 
system, be used to give priority to the high-speed device. 

It is possible to connect multiple devices to the non-maskable inter- 
rupt line except for the fact that the non-maskable interrupt is edge- 
sensitive. Therefore, the same logic that allows the IRQ to stay low until 
the status has been checked and the data transferred will keep the non- 
maskable interrupt line in a low state until such time as the first interrupt 
is serviced. If, subsequently to the first Interrupt of a non-maskable 
interrupt line, a second device which is collector OR'd would have 
turned on its status and collector-OR' d output, the clearing of the first 
Interrupt request would not cause the line to re-initialize itself to the 
high state and the microprocessor would ignore the second interrupt. There- 
fore, multiple lines connected to the non-maskable interrupt must be careful- 
ly serviced . 

In any case, NMI is always a high-priority vec'tored interrupt. 
By virtue of the fact that it goes to a different vector pointer, the 
microprocessor programmer can be guaranteed that in 17 cycles he can trans- 
fer data from the interrupting device on the non-maskable interrupt input. 

The TrQ and NKI are lines which, externally to the microprocessor, \ 
control the action to the microprocessor through an interrupt sequence. 
As mentioned during the discussion of the start function, the restart 
cycle is a pseudo-interrupt operation, with a different vector being 
selected for reset which has priority over non-maskable interrupt which 
in turn has priority over interrupt. There is also a software technique 
which permits the user to simulate an interrupt with a microprocessor com- 
mand, BRK. It is primarily used for causing the microprocessor to go to a 
halt condition or a stop condition during program debugging. 
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9,11 BRK - BREAK COMMAND 

The break command causes the microprocessor to go through an inter- 
rupt sequence under program control. This means that the program counter 
of the second byte after the BRK is automatically stored on the stack, 
along with the processor status at the beginning of the break instruction. 
The microprocessor then transfers control to the interrupt vector. 

Symbolic notation for break is PC + 2lP4 (FFFE)-+PCL (FFFF)-»'PCH. 

Other than changing the program counter, the break instruction 
changes no values in either the registers or the flags. 

The BRK is a single^byte instruction, and its addressing mode is 
Implied . 

As is indicated, the most typical use for the break instruction is 
during program debugging. When the user decides that the particular pro- 
gram is not operating correctly, he may decide to patch in the break 
instruction over some code that already exists and halt the program when 
it gets to that point. In order to minimize the hardware cost of the 
break w!)ich Is applicable only for debugging, the microprocessor makes use 
of the interrupt vector pointer to allow the user to trap when a break 
has occurred. In order to know whether the vector was fetched in response 
to an interrupt or in response to a BRK ins-ruction, the P status is stored 
on the stack, at stack pointer plus 1, containing a one in the break bit 
(B flag) position, indicating the Interrupt was caused by a BRK instruction. 
The B bit in the stack contains if it was caused by a normal IRQ. There- 
fore, the coding to analyze for this is as follows in Example 9.6. 



Example 9.7 : Break-Interrupt Processing 



Cycles Bytes 



A 
3 
2 
2 
11 



Check for A BRK 

PLA 
PHA 

AND // $ 10 
BNE BRKP 



Flag 



Load status register 
Restore onto Stack 
Isolate B Flag 
Branch to Break Programming 



Normal Interrupt Processing 
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This coding cnn be inserted at any point in the intcrrui>t processing 
routine. During debugging, if the user can afford the execution time, it 
should be placed immediately after the save routine. If not, it can be 
put at the end of cVie polling routine which gives a priority to Che 
polling devices as far as servicing tt>« interrupts. However, it should 
be noted that in order not to lose the break, the returns from all inter- 
rupts during debugging should go through an equivalent routine. 

Once the user has determined that the break is set, a second analysis 
and correction must be made. It does not operate in a normal interrupt 
manner of holding the program counter pointing at the next location in 
memory. Because of this, the value on the stack for the program counter 
is at the break instruction plus two. If the break has been patched over 
an instruction, thig is usually of no significant consequence to the user. 
However, if it is desired to process the next byte after the break instruc- 
tion, the use of decrement memory instructions in the stack must be used. 

It is recommended that the user take care of patching programs with 
breaks by processing a full instruction prior to returning and by then 
using jump returns. 

An interesting cliarac ter ist 1 c about the break instruction is that its 
OP CODE is all zeroes (O's); therefore, BRK coding can be used to patch 
f usable-link PROMS through a break to an E-ROM routine which Inserts patch 
coding. 

An example of using the break for patching is shown below: 
Example 9.8 : Patching with a Break Utilizing PROMs 



Old Code FC21 LDA 

FC22 05 
FC23 21 

FC24 Next OP CODE 



Patched FC21 BRK 00 

Code FC22 05 

FC23 21 

FC2A Next OF CODE 
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t 



The Interrupt vector routine points to: 

Patch LDA 
06 
21 
JMP 
24 
FC 

This coding substitutes: 

LDA 2106 
for the 
LDA 2105 
coding at 
FC21 

by use of the BRK and a break processing routine. 



9.12 MEMORY MAP 

A series of requirements have been discussed to this point for the 
memory organization which can be illustrated by the following memory map: 
Hex Address 

OOOO-OOFF RAM used for zero page and indirect memory addressing 
operation. 

0100-OlFF RAM used for stack processing and for absolute addressing. 
0200-3FFF Normally RAM. 
4aOO-7FFF Normally I/O 

8000-FFF9 Program storage normally ROM. 
FFFA Vector low address for NMI. 

FFFB Vector high address for NMI . 

FFFC Vector low address for RESET. 

FFFD Vector high address for RESET. 

FFFE Vector low address for IRQ + BRK. 

FFFF Vector high address for IRQ + BRK. 

The addressing schemes for I/O control between locations 4000 and 
8000 Hex, have not been fully developed. This is described in detail in 
the Hardware Manual, Chapter 2. The Zero Page addressing requires that 
RAM should be located starting in location 00. If more than one RAM page 
^8 necessary, RAM location 0100 through OlFF should be reserved' for 
the stack or at least a portion should be reserved for the stack 
with the rest of it being available to the user to use as normal RAM. 
Locations from 0200 up to 4000 are normally reserved for RAM expansion. 
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In small memory configurations such as are inherent in a R6530 class de- 
vice, in order to minimize the addressing lines, page two (02XX) will be 
normally used for input/output as opposed to using tlie ^OXX page which is 
used for devices which require significant amounts of RAM, ROM and 
I/O. 

Because of the fact that the R6500 has three very important vector 
points selected in highest order memory, it is usually more useful to 
write programs with the memory storage located at a starting address 
which allows the programmer to make sure that the last address in his 
ROM contains the start and interrupt vectors. Because of these alloca- 
tions, the user finds himself working in three directions. RAM is 
assigned in location 0000 working up. I/O devices are started at 
location 4000 starting up and ROM starts at location FFFF and works down. 
Although this seems like an unusual concept, one must remember that the 
hardware really only gives service to one part of memory at a time and, 
therefore, data locations have no priority one over the other. So start- 
ing at either end is just as useful a technique as starting at one end 
and working up. 

In order to take maximum advantage of the capability of the micro- 
processor, particularly when using a symbolic assembler, working data 
should be located starting in location 0, and stack addresses should 
be reserved until after analysis of the working storage requirements have 
been completed. Program storage should start in high order memory with 
some guess as to the amount of memory required being taken and that being 
taken as a start address. However, care should be taken to assign the 
three fixed vectors almost immediately at least symbolically as they are 
all necessary for correct operation of the microprocessor. 
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CHAPTER 10 
SHIFT AND MEMORY MODIFY INSTRUCTIONS 



W.O DtTlNlTION OF Starr AND ROTATE 

In many cases operations of the control systems must operate a bit at 
a time. Data are often available only bit-serial, and sometimes sequen- 
tial bit operations are the only way to solve a particular problem. 
Also, in order to combine bits into a field, shift and rotate instruc- 
tions are necessary. Multiply and divide routines all require the ability 
to move bits relative to one another in a full multiple-byte field. 

The shift instruction takes a register such as the accumulator 
and moves all of the bits in the accumulator one bit to the right 
or one bit to the left. Examples of the shift and rotate instructions 
in the R6500 are shown below: 



Example 10.1 : General Shift and Rotate 



Shift Left 



Rotate Left 



Right 


Be fore 


B7 


B6 


B5 


B4 


B3 


B2 


Bl 


BO 




After 





B7 


B6 


B5 


B4 


B3 


B2 


Bl 



Carry 



Be fore 
After 



Be fore 
After 



B7 


B6 


B5 


B4 


B3 


B2 


Bl 


BO 


B6 


B5 


B4 


B3 


B2 


Bl 


BO 






Rotate Right Before 
After , 



0*] 



B7 


B6 


B5 


B4 


B3 


B2 


Bl 


RO 


B6 


B5 


B4 


B3 


B2 


Bl 


BO 


C 



B7 


B6 


B5 


B4 


B3 


B2 


Bl 


no 


C 


B7 


B6 


B5 


B4 


B3 


B2 


Bl 
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As you can see from our example, moving data one bit to the right Is 
called shift right. The natural consequence of the shift right is that 
the Input bit or high-order bit in this case is set to 0. Moving the data 
in the register one bit to the left is called shift left. In this case, the 
is inserted In the low-order position. These are the two shift capabilities 
that exist in the R6500 microprocessor. 

It should be noted that in both cases, the bit that is shifted from 
the register — the low-order bit in shift right, and the high-order bit in 
shift left — is stored in the carry flag. This is to allow the programmer 
to test the bit by means of the carry branches that are available, and also 
to allow the rotate capability to transfer bits in multiple precision 
shifts. 

The rotate right instruction moves the data one bit to the right with the 
value of the carry bit becoming the high order bit of the register and the out- 
put bit from the shift being stored in carry. The rotate left instruction 
moves the data one bit to the left with the value of the carry bit becoming the 
low-order bit of the register and the output bit from the shift being stored 
in carry. t 

lO.I LSR - LOGICAL SHIFT RIGHT 

This instruction shifts either the accumulator or a specified memory 
location one bit to ttie riglit, with the higher bit of the result always being 
set to 0, and the low bit which is shifted out of the field being stored 
in the carry flag. 

The symbolic notation for LSR is 



The shift right instruction either affects the accumulator by shift- 
ing it right one bit, or is a read/modify/write instruction which changes a 
specified memory location but does not affect any internal registers. The 
shift riRht does not affect the overflow flag. The N flag is always reset. 
The Z flag is set if the result of the shift is and reset otherwise. The 
carry is set equal to bit of the input. 

LSR is a read/write/modify instruction and has the following address- 
ing modes: Accumulator; Zero Page; Zero Page,X; Absolute; Absolute, X. 
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10.2 ASL - ARITHMETIC SHIFT LEFT 

The shift left instruction shifts either the accumulator or the ad- 
dressed memory location one bit to the left, w.ith bit always being set 
to and the bit 7 output always being contained in the carry flag. ASL 
either shifts the accumulator left one bit or is a read/modi fy/wri te instruc- 
tion which affects only memory. 

The symbolic notation for ASL is FFH 1 1 | > »— 



The instruction does not affect the overflow bit, sets N equal to the 
result bit 7 (bit 6 in the input), sets Z flag if the result is equal to 
0, otherwise resets Z and stores the input bit 7 in the carry flag. 

ASL is a read/modify /write instruction and has the following address- 
ing modes: Accumulator; Zero Page; Zero Page, X; Absolute; Absolute. X 

10.3 ROL- ROTATE LEFT 

The rotate left instruction shifts either the accumulator or addressed 
memory left one bit, with the input carry being stored in bit and with the 
input bit 7 being stored in the carry flags. 

The symbolic notation for ROL is 



The ROL instruction either shifts the accumulator left one bit and 
stores the carry in accumulator bit or is a read/modify/write Instruction 
which does not affect the internal registers at atl. The ROL instruction sets 
carry equal to the input bit 7, sets N equal to the input bit 6, sets the 
Z flag if the result of the rotate is 0, otherwise it resets Z and does not 
affect the overflow flag at all. 

ROL is a read/modify/write Instruction and it has the following address- 
ing modes: Accumulator; Zero Page; Zero Page, X; Absolute; Absolute, X. 
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W.4 ROR - ROTATE RIGHT 

The rotate right instruction shifts either the accumulator or addressed 
memory right one bit with bit* shifted into the carry and carry shifted Into 
bit 7. 

The symbolic notation for ROR is 



B7 



BO 



The ROR instruction either shifts the accumulator right one bit and 
stores the carry in accumulator bit 7 or is a read/modlf y/wrlte Instruction 
which does not affect the internal registers at all. The ROR instruction sets 
carry equal to input bit 0. sets N equal to the input carry and sets the Z flag 
if the result of the rotate is 0; otherwise, it resets Z and does not affect 
the overflow flag at all. 

ROR is a read/modify/write instruction and it has the following address- 
ing modes: Accumulator; Zero Page; Absolute; Zero Page, X; Absolute, X. 



J0.5 ACCUMULATOR MODE ADDRESSING 

As indicated, all of the shift instructions can operate on the accumu- 
lator. This is a special addressing mode that is unique to the shift in- 
structions and operates with the following set of operations: 



Example 10.2 : Rotate Accumulator Left 



Cycles Address Bus Data Bus 



100 
101 

101 

102 
{ 



OP CODE 



Next 
OP CODE 



Next 
OP CODE 



External 
Operation 

Fetch Next 
OP CODE 

Fetch Dis- 
carded OP CODE 

Fetch Next 
OP CODE 

Fetch Second 
Byte 



Internal 
Operation 

Finish Previous 
Operation; Increment 
PC to 101 

Decode Current In- 
struction; Hold P- 
Counter 

Shift Through the 
Adder 

Store Results into A; 
Interpret Next OP CODE| 



As we can see, the accumulator instructions have the same effect as 
the single-byte non-stack instructions, in the sense that the instruction con- 
tains both the OP CODE and the register in which the operations are going 
to be performed; therefore, in cycle 2 the microprocessor holds the pro- 

lO-A 



gram counter, and in cycle 3 it fetches the same program counter location and 
starts the next instruction operation. At the same time, it is transferring 
the results from the adder into the accumulator; this Is because of the look- 
ahead and pipelining characteristics of the R6500 . The accumulator shift 
and rotate operations require only two cycles and one byte of memory. 

10.6 READ/MODIFY/WRITE INSTRUCTIONS 



The R6500 has a series of instructions which allow the user to 
change the contents of memory directly with a single Instruction, These 
instructions include all of the shift, rotate. Increment and decrement mem- 
ory instructions. The operation of each of these instructions is the same 
in that the addressing mode that is defined for the instruction is imple- 
mented the same way as if for normal Instructions, After the address has 
been calculated, the effective address is used to read the memory location 
into the microprocessor arithmetic unit (ALU) . The ALU performs the opera- 
tion and then the same effective address is used to write the results back 
into memory. The most difficult operation is the addressing mode Absolute 
Indexed which is Illustrated in Example 10.3 for the rotate left instruc- 
tion, ROL: 



Example 10.3 : Rotate Memory Left Absolute, X 



C ycle s 
1 



Address Bus 
100 

101 



Data Bus 



OP CODE 



ADL 



102 



ADH 

ADH, ADL + X ? 

ADH + C, Data 
ADL + X 

ADH + C. ? 
ADL + X 

ADH + C, 
ADL + X 



103 



Shifted 
Data 

OP CODE 



External 
Operation 

Fetch 
OP CODE 

Fetch ADL 



Fetch ADH 

False Read 

Fetch Value 

Destroy 
Memory 

Store 
Results 

Fetch Next 
OP CODE 



Internal 
Operation 

Finish Previous 
Operation, Incre- 
ment PC to 101 

Decode Current In- 
struction, Increment 
PC to 102 

Add ADL + X, Incre- 
ment PC to 103 

Add Carry from 
Previous Add to ADH 



Perform Rotate, 
Turn on Write 

Set Flags 

Increment PC to lOA 
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Cycle 4 is a wasted cycle because read/modify/write instructions should 
wait until the carry has been added to the address high in order to avoid 
writing a false memory location. Tliis is the same logic tliat is used in 
the store instruction in which the look-ahead or the short-cut addressing 
mode is not used. Cycle 4 is an intermediate read, and cycle 5 is when the 
actual data that is going to be operated on is read. 

The address lines now hold at that address for cycles 5, 6 and 7. The 
microprocessor signals both itself and the outside world those operations 
during which it will not recognize the ready line. It does tliis by pulling 
tlie Write line. The Write line is pulled in cycle 6 because data are writ- 
ten into the memory location that is going to be written into again in 
cycle 7 with correct data. 

Because data bits read from memory have to be modified and returned, 
there is no pipelining effect other than tlie overlap of the adding in the 
address low and index register. The seven cycles required to perform read/ 
modify/write Absolute Indexed, X instruction is the worst case in timing 
for any section of the machine except for interrupt. This unique ability 
to modify memory directly is perhaps best illustrated by the coding in 
Example 10.^ wliich is used to shift a 4-bit BCD number, which has been 
accumulated in the high four bits of the accumulator as part of the decoding 
operation, from the accumulator into a memory field. Figure 10,1 is a 
flow chart of this example. Examples such as this often occur in point- 
of-sale terminals and other machines in which ROD data are entered sequen- 
tially. This example assumes that the value is keyboard entered, through 
vjhich data are entered into the accumulator from left to right but have to 
be shifted into memory from right to left. Tlie value in tlie field before 
the shift is a 1729 which after the shift will be a 1 7 , 295. 
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Set Y = 4 
for counting 
number of bits moved 



— ► 


Set X = 4 
to move all eight 
digits , two digits 

at a time 






r 




Move one bit from 
accumulator into carry 






1 ^ 




Rotate data once 
into next value 


i 




Decrement X 
to point at next value 




k 



Decrement Y 




Flow Chart for Moving in a New BCD Number 
FIGURE 10. J 
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Example lO.A: Move a New BCD Number into Field 



Before After 



Field 00 00 

00 01 



17 12 
29 95 



Accumulator 50 00 



LOOP 2 
LOOP 1 



Bytes 

2 
2 
1 
3 
1 
2 

1 t 



1^ bytes 



CoJ in g 

Instruction 

LDY h 
LDX 4 
ASLA 

ROL Price -1, X 
DEX 

BNE LOOP 1 
DEY 



BNE 



LOOP 2 



Set up for 4 Moves 

Shift the Field 1 Bit 
Shifts Four Times. 



There are several new concepts introduced in this example; the first 
is the use of index register Y as just a counter to count the number of 
times the character has been bit-shifted. It is a common approach to use 
bit shifts, as is implemented in the R6500 family, to shift data into 
memory. The power of being able to communicate directly in memory is shown 
by shifting bits from one byte to the next byte using a single ROL Indexed 
instruction. This example uses a loop within a loop and it should be 
noted that LOOP 1 occurs four times for every tijne LOOP 2 occurs. The In- 
ternal loop is very important in the sense that this loop executes 16 
times for the problem; therefore, its execution time should be optimized. 

In addition to having the ability to shift and rotate memory, the 
R6500 has the ability to increment and decrement memory locations. 
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W. 7 INC - INCREMENT MEM OR Y BY ONE 

This Instruction adds 1 to the contents of the addressed memory loca- 
tion. 

The symbolic notation is M + 1 M. 

The increment memory instruction does not affect any Internal registers 
and does not affect the carry or overflow flags. If bit 7 is on as the 
result of the increment, N is set, otherwise It is reset; if the increment 
causes the result to become 0, the Z flag is set on, otherwise it is reset. 

The addressing modes for increment are: Zero Page; Zero Page, X; Abso- 
lute; Absolute, X. 

!0.8 DEC - DECREMENT MEMOR Y BY ONE 

This instruction subtracts 1, in two's complement, from the contents 
of the addressed memory location. 

Symbolic notation for this instruction is M - 1 M. 

The decrement instruction does not affect any internal register in the 
microprocessor. It does not affect the carry or overflow flags. If bit 7 
is on as a result of the decrement, then the N flag is set, otherwise it 
is reset. If the result of the decrement is 0, the Z flag is set, other- 
wise it is reset. 

The addressing modes for decrement are: Zero Page; Zero Page, X; 
Absolute; Absolute, X. 

In many examples through the report, we have used the ability to incre- 
ment and decrement registers in the microprocessors. The advantages of 
incrementing and decrementing in memory are that it is possible to kucp 
external counters or to directly influence a bit value by means of these 
instructions. It is sometimes useful during I/O instructions. 

10.9 GENERAL NOTE ON READ/MODIFY/WRITE INSTRUCTIONS 

The ability to read, modify and write memory is unique to R6500 
class microprocessors. The usefulness of the instructions is limited only 
by the user*s approach to organizing memory. Even though the instructions 
are fairly long in execution, they are significantly shorter than bi/lng 
to load and save other registers to perform the same function. I xptr Lcnce 
in organizing programs to take advantage of this manipulation ot m. r.i.ry 
will allow the user to fully appreciate the power of these ins t rucL • ms . 
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CHAPTER 1 1 
PERIPHERAL PROGRAMMING 



U.O REVIEW OFR6520 FOR I/O OPERATIONS 

It should be noted that in the following discussions, the major 
difference between the R6530 I/O and the main register of the R6520 
is that the extra bit in the control register need not be used in the 
R6530. All registers in the R6530 are directly addressable. 



Example 11.1 : The R6520 Register Map 



I 

, A DATA DIRECT- i 



PIAD 
PI AC 
PIBD 
PIBC 



Base Address 

* + 1 

* + 1 

* + 1 

* + 1 



' B DATA DIRECT-) 



ION (AD) 



1 



ION (BD) 



I 



A DATA (AD) 



I J 

B DATA (BD) 



A CONTROL (AC) 



B CONTROL (BC) 



A SIDE B SIDE 

In Example 11.1 a progiamming form to describe the PIA is shown. 
The programming form is used in the R6500 assemblers. The notation * = 
is employed to define any location. The notation means that the assembler 
instruction counter is set equal to the value following the equal sign. 
The expression *■»*+! causes the assembler to recognize that there is 
one byte of memory associated with the term; therefore, we can see 
that the definition of the four registers PIAD, PIAC, PIBD and PIBC 
are consecutive memory locations starting at some base address, with 
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the first byte addressed as PIAD. the second byte addressed as PIAC, the 
third byte addressed as PIBD, and the fourth byte as PIBC. This is 
a normal way an R6520 would be organized and this is the way the 
programming form should be set up. The base address is picked up by 
an algorithm described in the hardware manual, but normally it is a 
value between ^OOA and 4080 Hex. Each R6520 is given a base address 
which works progressively up from A004 Hex. 

In Example 11.1 two registers are shown in dotted lines. This is 
because each of the A DATA (AD) and B DATA (BD) parts of the R6520 
are actually two registers having the same address, one which specifies 
the direction of each of the input/output paths (the Data Direction 
Register), the second one which is actually the connection to the in- 
put/output paths (the Data Register). Because of pin limitations on 
the R6520, the microprocessor can only directly address one of the 
-registers at a time. Differentiation as to which register is being con- 
nected to the microprocessor is a function of bit 2 in the respective 
control register (AC and BC) . If bit 2 is off. the Data Direction Reg- 
ister is being addressed; if it is on. the Data Register is being ad- 
dressed , 

During the initialization sequence, therefore, the R6520 starts 
out with all registers at zero. This means that the microprocessor is 
addressing the Data Direction Register. The PIA Initialization is done 
by writing the direction of the pins into the Data Direction Register 
(AD, BD) and then setting on the control flag as described below. After 
that, the program will normally be dealing with the data registers. 

Example 11.2 : General PIA Initialization 

LDA n DIRECT 
STA PIAD 

LDA CONTR 
STA PIAC 



Initialize Direction 
Initialize Control 
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Example 11.2 illustrates a general form of initialization and can 
be completed for as many PIA*s as there are in the system. 

R6520 INTERRUPT CONTROL 

The R6520 has a basic interrupt capability which is under control 
of the programmer. Almost all R6500 I/O devices that allow interrupts 
have an interrupt control register which permits the user to disable the 
interrupt. This will keep inputs that are not necessarily active from 
causing spurious interrupts which must be handled by the microprocessor. 
Examples of this are open tape loops or other signals which have high- 
impedance, noise-sensitive inputs except when connected to some kind of 
media. In this type of application, the interrupt is normally enabled 
by some physical action from the person using the device, such as load- 
ing of the cassette, pushing the power-on switch, etc. In the case of 
the R6520. there are two interrupt causing conditions for each 
control register. 

Each of these interrupts concerns itself with one input pin. 
The Control Register allows the programmer to decide whether or not the 
pin is sensitive to positive edge signals or negative edge signals and 
whether or not an Interrupt shall occur when the selected transition 
has occurred . 

It should be noted therefore, that it is possible for a line to 
cause a status bit to be set without causing an interrupt. The com- 
prehensive I/O Program in Section 11.5 uses this combination. 
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Example 11.3: Interrupt 


Mode Setup 






Bit 7 Status Bit: 


Bits 1 





Interrupt 


Set on Negative Kdge 








No 


Set on Negative Edge 





I 


Yes 


Set on Positive Edge 


1 





No 


Set on Positive Edge 


1 


i 


Yes 


Bit 6 Status Bit: 


Bits A 


3* 


Interrupt 


Set on Negative Edge 








No 


Set on Negative Edge 





1 


Yes 


Set on Positive Edge 


1 





No 


Set on Positive Edge 


1 


1 


Yes 



*If Bit 5 Equals Zero 



The proper combination of bits is usually determined during the 
design of the R6520 interconnection and forms the constant that is 
loaded in the control register; this constant should contain bit 2 
on. For example, to allow bit 7 to be set on negative going signals 
with interrupt enable and bit 6 to be set on positive signals with 
interrupt disable, the control value would be Hex 15. 

With bit 5 on, the pin that controls bit 6 can be set as an 
output pin. The output pin is either controllable by the microprocessor 
directly or acts as a handshake to reflect the status of reads and 
writes of the data register. The operation of the output pins CA2 , CB2 
depends on how bits 5. A, and 3 are programmed, as shown in Example 11. A. 



Example 11. A : CA2 . CB2 Output Control 
CA2 Output With : Bit 5 On 

Bit 4 Bit 3 

Low on Read or Write until 
Bit 7 On 

Low on read or write for 
one 

I 

Always 
Always 1 



1 

1 
1 1 



The decision as to whether or not to use the one cycle low until 
bit 7 comes on is a hardware decision, depending on the device that 
is hooked to the pin. 

It should be of interest to the programmer to note that bit 6 con- 
trols pins known as CA2 or CB2 which can be considered to be auxiliary 
outputs controlled by bit 3, assuming the processor is initialized 
so that bit 5 and bit 4 are ones. 

Example 11.5 shows the control of bit 3 using AND and OR 
instructions; however, it should be noted that this technique 
applies for any individual bit in the PIA data direction register, also. 

Example 11.5 : Routine to Change CA2 or CB2 Using Bit 3 Control 
Set CA2 

LDA PI AC 

ORA //$08 

STA PIAC 

Clear CA2 

LDA PIAC 
AND //$F7 
STA PIAC 

Note: $ - Direction to Assembler for Hex Notation 

// - Direction to Assembler for Immediate Addressing 

By similar techniques, every pin associated with I/O registers of the 
R6520 can be controlled. There are two particular considerations to remember: 

1. In the. R6520, both bit 6 and bit 7 are cleared on either A or B 
side by reading of the corresponding data register If bit 6 has 
been set up as an input. This means that polling sec^uences 

for I/O instructions should read only the status registers and 
then read the data registers after the status has been determined; 
otherwise, false clearing of the status data may occur. 

2. Even though the handshake for the CB2 pin is on write of B 
data, a read of B data must be done to clear bit 7. 
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11.2 IMPLEMENTATION TRICKS FOR USE OF THE R6520 PERIPHERAL INTERFACE ADAPTl 
11.2.1 Shortcut Polling Sequences 

In section 9.7, the techniques for using a LOAD A to poll for 
interrupts, was .covered ; however, the I/O devices on the R6520 
can either set bit 6 or bit 7 to cause an Interrupt; therefore, 
a different technique is required to poll a series of 6520' s each 
one of which could have caused the interrupt. It is for this pur- 
pose that the BIT instruction senses both bit 6 and bit 7. Coding 
for a full poll of a PIA is as shown below. 

Example 11.6 : Polling the R652Q 

Interrupt Vector JMP STORE 

LDA //CO Set up Mask for 6 and 7 

BIT PIAAC Check for Neither 6 or 7 

BEQ NXTl 

BMI SEVEN If 7, Go to Save- 

Otherwise Clear 

Process BIT 
6 INTERRUPT 
NXTI BIT PIABC 
BEQ NXTZ 
etc. 



This program takes full advantage of the BIT instruction by 
checking for both bit 7 and 6 clear. BMI to SEVEN just checks that 
N is on and is a higher priority. If bit 6 is one, the overflow bit 
will also be set, allowing the finish of the process bit 7 routine 
to test the overflow and jump back to the process bit 6 coding. Bit 
6 and bit 7 are sampled by the single BIT instruction. Speed is 
accomplished by loading the mask for just bits 6 and 7 'into the 
register which allows the BEQ instruction to determine that neither 
of the two flags is on. 

This routine depends on the fact that in the R6520, if CA2 
or CB2 is an output, bit 6 is always zero. 
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In the microprocessor, there is a definite positional pref- 
erence for the testing of single bits. In the R6520 Data Direct- 
ion Register, it is possible to select any combination of input/ 
output pins by the pattern Chat is loaded in the Data Direction 
Register. A 1 bit corresponds to an output and a bit 
corresponds to an input. The natural tendency would be to use 
R6520S with all eight bits organized into a byte. There is an 
advantage to organizing this way when the eight bits are to be 
treated as a single byte by the program. This may not be the 
case; more often the bits are a collection of switches, coils, 
lights, etc. 

With such combinations, advantage should be taken of the fact 
that bit 7 is directly testable so that a more useful combination 
of eight pins on one R6520 register would be seven outputs and 
a single input with the single input on bit 7, This organization 
allows the programmer to load and branch on that location without 
ever having to perform a bit or shift instruction to isolate a 
particular bit. 

A similar capability for setting a single bit involves the 
organization of data with seven inputs and a single output located 
in bit 0. This bit may be set or cleared by an INC or DEC instruc- 
tion without affecting the rest of the bits in the register because 
the input pins ignore signals written from the microprocessor. 
Therefore, the more skilled R6500 programmer will often mix single 
: outputs on bit and a single input on bit 7 with bits of the 
corresponding opposite type. 
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11.2.3 Use or Rl-AU/MOUirY/WlUTi: InslrticLlon Kor Kuy board I'licodins 

A rather unique use of the memory with a read/modify/write 
operation involves setting the data register at all zeros, then 
employing the three state output of the B side to sample a keyboard. 
The following Figure 11.1 shows the connection for a 6A-key key- 
board organized 8x8: 



B Side 



8x8 Swltth 

Decode 

Matrix 































































\ 




























































































' 1 









A SIDE 



Keyboard Encoding Matrix Diagram 
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The B side is set up to act as a strobe so that each of 
the output lines Is grounded during one scan cycle. The eight 
A side data inputs are then sampled and decoded by the micro- 
processor, giving a 64-key keyboard which is directly trans- 
latable into code. 

Figure 11.1 and Example 11.7 make use of the capability 
of the microprocessor to move a bit throught the R6520 register 
; location. This program also utilizes the compare instruction and 
the ability to detect a carry during a shift. 

Example 11.7 : Coding for Strobing an 8 x 8 Keyboard 

Output Strobe is Indicated by a one in Data Director Register. 
Any connection is indicated by a zero in a register bit. 



LDX 90 
STX PIABD 
LDA PI ABC 
AND li/FB 
STA PIABC 
STX PIABC 

SEC Set low end bit on 
LOOP ROL PIABD 
BCS DONE 
LDA PIAAD 
CMP #FF 
BEQ LOOP 
DONE 



Initialize B Data Register 

Initialize Control Register to 
Address Data Direction Register 

Shift for Strobe 

if All Sampled, Exit 

Check for No Zeros 

If Any Zeros, Then Process Them 



A and PIABD can now be used to find out Just what key is 
depressed. 
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Svt Unt.'i He^ister 
To Al J X.L'ros 














Set Control KcRister 




Initialize 




To I'nlnt At 




(■"or 




Datn Direction Kepistor 




Strobing 








Set Up Dirt-cLion Ri'kIsUt 






KqiKil T(i All Zuros 






And Set Carry 







3 



Shift Left 
St K.binj: K* ^;isl<.r ftil)) 




Then process Accmulator 
for Zero Bits 

Keyboard Strobe Sequence 

FIGURE 11.2 
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tl.3 R6530 PROGRAMMING 

Although they have separate addressing, the Data Direction and 
Input/Output Registers operate the same as on the R6520. 

Programming of the Interval Timer has some special considerations. 
First of all, the time is effectively located in all addresses from 
XXXA-XXXF. By picking the proper address, the programmer is able to 
control the P scale for the timeout. Initialization of the Interval 
Timer is done by a LOAD A followed by STORE A into the timing count. 
The value stored in the timing counter represents the number of states 
which the counter will count through. The address used to load will 
determine how many additional divisions of the basic clock cycle will 
be counted. 

When the counter finally counts to zero, it continues to count 
past zero at the one-cycle clock rate in order to give the user an 
opportunity to sample the Status Register, and to then "come backh- 
and read the Count Register in order to determine how long it has 
been since an interrupt occurred. 

Servicing an interrupt is the same for this Control Register as 
for any other interrupting register. Bit 7 is set in the Status 
Register to indicate that the Interval Timer is in the interrupt 
state and bit 7 is reset by the reading of the Counter. 

11.3.1 Reading of the Counter Registe r 

Because of the nature of counting past zero, the number in the Count 
Register is in two's complement form. It can be added to directly and can 
be used to correct the next count in a sequential string of counts or for 
correction for one-cycle accuracy. 

U4 If O WTO OR CA NIZE TO IMPLEMENT CODING 

The specific details of organizing to get coding assembled Is a 
function of the assembler software used. 
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The major advantages of employing an assembler are that the 
assembler takes mnemonics and labels and calculates the fixed code. 
Reference to the OP CODE tables in the appendix shows that coding in 
Hex Is quite difficult because there is no ordered pattern to the 
instruction Hex codes. 

An assembler allows one to specify all inputs and outputs 
in symbolic form on a documented listing. Symbolic addressing 
is a technique which has the following advantages over numerical 
addressing : 

1. It permits the user to postpone until the last minute actual 
memory allocation in a program which is being developed. In 
a microprocessor that has memory-oriented features such as 
Zero Page, memory management is important. It is desirable 
to have as many as possible of the read/write values in the 
Zero Page. However, until the coding Is complete, the organi- 
zation of Zero Page may be in doubt. Values which are 
originally assigned in Zero Page may not be as valuable 
after some analysis of the coding either Indicates that the 
applications of these values use indirect references or index- 
ing by Y which does not allow the program to really take 
advantage of Zero Page locations whereas some other code 
which may not be as frequently used might still result in a 
code reduction by use of Zero Page. This allocation, if all 
the fields are defined symbolically, can be done on the 
final assembly without any changing in the user's codes. 

2. Use of symbolic addresses for programming braches leads to 
a better documented program and calculation of relative 
branches is difficult and subject to change any time a 
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coding change Is made. For example, if one has organized 
a program with a loop in which three or four branches all 
return to the same point and then discovers a programming 
error which requires a single instruction to be added 
between the return point and various branches, each branch 
would have to be edited and recalculated. The symbolic 
assembler accomplishes this automatically on the next 
assembly. 

11.4,1 Label Standards 

The R6500 assemblers have been done on a reserve word 
basis In which the various mnemonics which have been described 
are always considered to be OP CODE mnemonics. If any three 
character fields exactly match a mnemonic, then the assembler 
assumes that the field is an OP CODE and proceeds to evaluate 
the addressing. Any other label may be located in free-form 
anywhere In the coding. This means that one should organize labels 
in such a manner that a three-character label will not Inadvertently 
be considered an OP CODE. The easiest way to accomplish this is 
always to follow a pattern on labels. 

Good programming practice requires that the user develop 
a systems flow chart for his own basic program and individual 
flow charts for subroutines before starting the coding. From 
the time the routine Is flow-charted. It is very easy for the 
user to then assign a mnemonic label to the basic subroutine. 

In this text, notations like LOOP, LOOP 1, etc. are used. 
In an ADD, loop would be ADLP. 

The R6500 assembler allows six characters for labels. It is good 
practice to use two characters to generally identify the subroutine, two 
more characters for mnemonic purposes, and then a numbering system which 
allows correlation between various addresses within a subroutine. By 
strictly numbering so that ADLPl is different from ADLP3, each can be 
addressed within the same LOOP. 
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With six-character labels, there are a huudred com- 
binations of code which could be utilized in a given routine or 
loop without the user having to think through the rest of 
mnemonic notation. The use of characters plus a numeric for 
all references is sound programming practice. The advantage 
of this technique Is that it permits one to employ three-character 
mnemonics without ever interfering with the reserved word of 
the microprocessor OP CODE mnemonics, because they never have a 
numeric in the mnemonic, 

11.5 COMPREHENSIVE 1/0 PROGRAM 

Figure 11.3 demonstrates the program flow in support of the Cross- 
Assembler listing (Example 11.9) of a time-sharing routine of a program 
that illustrates the use of the indexed indirect to perform a search of 
eight devices which have active signals for servicing. The implementa- 
tion of the eight devices is accomplished in R6520's, where the R6520 
status is set up to be a flag in bit 7 of a Control Register. 

It is assumed that ttie PIA's are connected in the normal manner 
of Status Register Address equal to Uata Register Address + 1. 

The following table and flow chart defines the program implemented 
in the example. 

Table ill contains the address of all of the R620 Status Registers. 

Table //2 contains the address of the put-away location for the 
respective data. 



t 
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Table in 



PIA #1 



PIA If I ADL 



STATUS 



Table a 2 



ADL 






ADH 





List 




Value 1 




Value 2 




VaiiiP ^ 


etc . 
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i 



Initialize Index 


to End (if T.ihU' 






>• 




Fetch Next Status Register 



Yes 




Decrt-mcnl X by 2 




Decrement 
to point at 


Table I as Indexed 
Data Regi ster 




Feti h 


D.Ttn usin^ 
1, liidcx<'d 




Store 
Table 


Data using 
2, Indexed 




Increment 
to point 


Table 2 Pointer 
at Next Address 




IncretnenL 
back 


Tiib le 1 to point 
at Status 



Program Flow — Polling for Active Signal 
FIGURE 11.3 
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Example 11.8 : Polling for Active Signal 



IT OOOC 

It 0001 

tf 0010 

» oou 

II 0014 

II OOlt 

I) oou 

» 001* 

IS OOK 

i» oou 

II OOJO 

11 

H OOII 

10 0100 

n oiio 

11 OIAO 

IJ OlFO 

14 0)*0 

Ji 01»0 



CAM) SERIAL NUtttCM 

AN 5TSIEM5 



' rOLLINC ■ rtRIPHEIULS 



-MfMORY LOCATIOM 



0) *0 
07 *0 

09 40 
01 40 
11 40 

1) 40 
11 40 

n 40 

00 01 

10 0] 
AO 01 

ro 01 

40 0) 

M OJ 



SIT TAILES AW STOUCt AIEAS 



•-J01 

TAiLri .Miu) riAiAC 
.wou riAiK 
WOKS riAiAc 
wou rtAiK 
wou riAiAC 

.WORD fIAJ»C 

woM) riA4AC 

.UOtD TlAiK 

TAiui .uoKD smti 

.WORD STO«EI 
WORI) STOIt) 

.uoto smi4 
.uctD ijxmti 



Ct«li or n» PtmrHEitAi coigl 



rOIHTClS TO STOU INPUT IMTA ttOH FEtlPMIRALS 



SIOHEI •-•+«) 



-^KOORAM LOCATtOH 



EC 04 
EC04 
ECOJ 



PC« 

rcOE 
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APPENDIX A 

INSTRUCTION LIST, 
ALPHABETIC BY MNEMONIC, 

DEFINITION OF 
INSTRUCTION GROUPS 
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/I./ INTRODUCTION 

The microprocessor Instruction set is divided into three basic groups. 
The first group has the greatest addressing flexibility and consists of 
the most general-purpose Instructions such as Load, Add, Store, etc. 
The second group Includes the Read, Modify, Write instructions such as 
Shift, Increment, Decrement and the Register X movement instructions. The 
third group contains all of the remaining instructions. Including all stack 
operations, the register Y, compares for X and Y, and instructions which do 
not fit naturally into Group One or Group Two. 

There are eight Group One Instructions, eight Group Two instructions, 
and 39 Group Three instructions. 

The three groups are obtained by organizing the OP CODE pattern to 
give maximum addressing flexibility (16 addressing combinations) to Group 
One, and to give eight combinations to Group Two instructions; the Group 
Three instructions are basically Individually decoded. 

A. 2 GROUP ONE INSTRUCTIONS 

Group One instructions are: Add With Carry (ADC), And (AND), Compare 
(CMP), Exclusive Or (EOR) , Load A (LDA) , Or (ORA) , Subtract With Carry (SBC), 
and Store A (STA) . Each of these Instructions has a potential for 16 address 
Ing modes. However, in the R6502 through R6507 and R6512 through R6515, 
only eight of the available modes have been used. 

Addressing modes for Group One are: Immediate, Zero Page, Zero Page 
Indexed by X, Absolute, Absolute Indexed by X, Absolute Indexed by Y, 
Indexed Indirect, Indirect Indexed. The unused eight addressing modes are 
to be used in future versions of the R6500 product family to allow 
addressing of additional on-chip registers, of on-chip I/O ports, and to 
allow two-byte word processing. 



A S GROUP TWO INSTRUa IONS 

Group Two instructions are primarily read, modify, write instructions. 
There are really two subcategories within the Group Two instructions. 
The components of the first group are shift and rotate instructions and 
are: Shift Right (LSR) , Shift Left (ASL) , Rotate Left (ROL) , and Rotate 
Right (ROR). 

The second subgroup includes the Increment (INC) and Decrement (DEC) 
instructions and the two index register X instructions. Load X (LDX) and 
Store X (STX) . These instructions would normally have eight addressing 
modes available to them because of the bit pattern. However, to allow 
for upward expansion, only the following addressing modes have been de- 
fined: Zero Page, Zero Page Indexed by X, Absolute, Absolute Indexed 
by X, and a special Accumulator (or Register) mode. The four shift in- 
structions all have register A operations; the incremented or decremented 
Load X and Store X instructions also have accumulator modes, although the 
Increment and Decrement Accumulator has been reserved for other purposes. 
Load X from A has been assigned its owi\ mnemonic, TAX. Also included in 
this group are the special functions of Decrement X which is one of the 
special cases of Store X. Included also in this group of the X decodes 
are the TXS and TSX instructions. 

All Group One instructions have all addressing modes available to 
each instruction. In the case of Group Two instructions, another address-, 
ing mode has been added — that of the accumulator, and the other special ^ 
decodes have also been implemented in this basic group. However, the ^ 
primary function of Group Two instructions is to perform some memory | 
operation using the appropriate index. 

It should be noted for documentation purposes tiiat the X instructions 
have a special mode of addressing in which register Y is used for all in- 
dexing operations; thus, instead of Zero Page Indexed by X, X instructions' 
have Zero Page Indexed by Y, and instead of having Absolute Indexed by X,^ 
X instructions have Absolute Indexed by Y. 



A.4 GROUP THREE INSTRUCTIONS 

There are really two major classifications of Group Three in- 
structions; the modify Y register instructions, Load Y (LDY) , Store Y 
(STY), Compare Y (CPY) , and Compare X (CPX) , instructions actually 
occupy about half of the OP CODE space for the Group Three instructions. 
Increment X (INX) and Increment Y (INY) are special subsets of the Compare X 
and Compare Y instructions, and all of the branch instructions are in the 
Group Three instructions. 

Instructions in this group consist of all of the branches: BCC, BCS , 
BEQ, BMI, BNE, BPL, BVC and BVS . All of the flag operations are also de- 
voted to one addressing mode; they are: CLC, SEC, CLD, SED, CLI, SEI and 
CLV. All of the push and pull instructions and stack operation instructions 
are Group Three instructions. These include: BRK, JSR, PHA, PHP, PLA and 
PLP. The JMP and BIT instructions are also included in this group. There 
is no common addressing mode available to members of this group. Load Y, 
Store Y, BIT, Compare X and Compare Y have Zero Page and Absolute, and all 
of the Y and X instructions allow Zero Page Indexed operations and Immediate. 
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APPENDIX B 
INSTRUCTION LIST, 
ALPHABETIC BY MNEMONIC, 
WITH OP CODES, EXECUTION CYCLES 
AND MEMORY REQUIREMENTS 



B-1 



The following notation applies to this summary: 



A Accumulator 

X, Y Index Registers 

M Memory 

P Processor Status Register 

S Stack Pointer 

/ Change 

_ No Change 

+ Add 

A Logical AND 
Subtract 

V Logical Exclusive Or 
+ Transfer from Stack 
+ Transfer to Stack 

Transfer to 
Transfer to 

V Logical OR 

PC Program Counter 

PCH Program Counter High 

PCL Program Counter Low 

OPER Operand 

Immediate Addressing Mode 



Note: Shown in parentheses at the top of each table a 

reference number (Ref: XX) which directs the user to 
the particular Section in the R6500 Microcomputer 
Family Programming Manual in which the instruction 
is defined and discussed. 



B-2 



ADC 



Add memory to accumulator with carry 
Operation; A + M+ C-^A, C 

(Ref: 2.2.1) 



ADC 



N C I D V 
///--/ 



Addressing 


Assembly Language 


OP 


No, 


No . 


Mode 




Form 


CODE 


Bytes 


Cycles 


Innnediate 


ADC 


// Oper 


69 


2 


2 


Zero Page 


ADC 


Oper 


65 


2 


3 


Zero Page, X 


ADC 


Oper, X 


75 


2 


4 


Absolute 


ADC 


Oper 


6D 


3 


4 


Absolute, X 


ADC 


Oper, X 


7D 


3 


4* 


Absolute, Y 


ADC 


Oper, Y 


79 


3 


4* 


(Indirect, X) 


ADC 


(Oper, X) 


61 


2 


6 


(Indirect), Y 


ADC 


(Oper) , Y 


71 


2 


5* 



Add 1 if page boundary is crossed. 



AND 



"AND" memory with accumulator 
logical AND to the accumulator 

Operation :AAM-^A NZCIDV 

/ / 



(Ref: 2.2.4.1) 



AND 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 




Form 




CODE 


Bytes 


Cycles 


Immediate 


AND 


/r' Oper 




29 


2 


2 


Zero Page 


AND 


Oper 




25 


2 


3 


Zero Page, X 


AND 


Oper, 


X 


35 


2 


4 


Absolute 


AND 


Oper 




2D 


3 


4 


Absolute, X 


AND 


Oper, 


X 


3D 


3 


4* 


Absolute, Y 


AND 


Oper , 


Y 


39 


3 


4* 


(Indirect. X) 


AND 


(Oper 


X) 


21 


2 


6 


(Indirect) , Y 


AND 


(Oper), Y 


31 


2 


5* 



* Add 1 if page boundary is crossed. 



B-3 



ASL 

Operation : C 



ASL Shift Left One Bit (Memory or Accumulator) 



ASL 



7 


6 


5 


.[3 


2 


1 






BCC 



N -a C 1 D V 

/ / / 



(Ref: 10.2) 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Fo rm 


CODE 


Bytes 


Cycles 


Ac c utnu 1 a t o r 


ASL A 


0A 


1 


2 


Zero Page 


ASL Oper 


06 


2 


5 


Zero Page, X 


ASL Oper, X 


16 


2 


6 


Absolute 


ASL Oper 


0E 


3 


6 


Absolute, X 


ASL Oper, X 


IE 


3 


7 




BCC Branch on Carry Clear 






BCC 


i: Branch on C = 




N S 


C I D V 






(Ref: 4.1.2.3) 








Address ing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Relative 


BCC Oper 


90 


2 


2* 



BCS 

Operation: Branch on C - 1 



BCS Branch on carry set 



(Ref: 4.1.2.4) 



BCS 



N 2 C I D V 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Relative 


BCS Oper 


B0 


2 


2* 



* Add 1 if branch occurs to same page. 

* Add 2 if branch occurs to next page. 



BEQ 

[Operation: Branch on a =« 1 



BEQ Branch on result zero 
(Ref: 4.1.2.5) 



BEQ 



N a C I D V 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Relative 


BEQ Oper 


F0 


2 


2* 



* Add 1 if branch occurs to same page. 

* Add 2 if branch occurs to different page. 



* Add 1 if branch occurs to same page. 

* Add 2 if branch occurs to next page. 



B-4 



B-5 



N 



BIT 



BIT Test bits in memory with accumulator 
Operation: AAM, M^->-N,M^->^V 

Bit 6 and 7 are transferred to the status register. N S C I D V 

If the result of AAM is zero then Z = 1, otherwise M_/ 

7 6 

Z = 



BIT 



(Ref : 4.2.2.1) 



Address ing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Zero Page 


BIT Oper 


24 


2 


3 


Absolute 


BIT Oper 


2C 


3 


4 



BMI 




BMI Branch on result minus 






BMI 


Operat ion 


Branch on N = 1 


(Ref: A. 1.2.1) 


N -g 


C I D V 






Address ing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 

Cycles 




Relative 


BMI Oper 


30 


2 


2* 



* Add 1 if branch occurs to same page. 

* Add 2 if branch occurs to different page. 



B-6 



BNE 




BNE Branch on result not zero 




BNE 


Operation 


: Branch on Z - 


(Ref: 4.1.2.6) 


N * 


C I D V 






Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 




Relative 


BNE Oper 


D0 


2 


2* 



* Add 1 if branch occurs to same page. 

* Add 2 if branch occurs to different page. 



BPL 




BPL Branch on result plus 






BPL 


Operation 


: Branch on N = 


(Ref: 4.1.2.2) 


N B 


C I D V 






Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 




Relative 


BPL Oper 


10 


2 


2* 



* Add 1 if branch occurs to same page. 

* Add 2 if branch occurs to different page. 



B-7 



BRK 




BRK Force Break 






BRK 


Operation 


: Forced Interrupt 


PC + 2 + P 1 

(Ref: 9.11) 


N « 


C I D V 
- 1 






Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 




Implied 


BRK 


0(3 


1 


7 


1. A 


BRK command cannot be masked by setting I. 








BVC 




BVC Branch on overflow clear 




BVC 


Operation 


: Branch on V = C 


(Ref: 4.1.2.8) 


N « 


C I D V 






Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No, 
Byted 


No. 
Cycles 




Relative 


BVC Oper 


50 


2 


2* 



* Add 1 if branch occurs to same page. 

* Add 2 if branch occurs to different page. 



B-8 



BYS 



BVS Branch on overflow set 



BVS 



Operation: Branch on V - 1 



N Z C I D V 



(Ref: 4.1.2.7) 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Relative 


BVS Oper 


70 


2 


2* 



* Add 1 if branch occurs to same page. 

* Add 2 if branch occurs to different page. 



CLC 

Operation: C 



CLC Clear carry flag 
(Ref: 3.0.2) 



CLC 



N ^ C I D V 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Implied 


CLC 


18 


1 


2 



B-9 



CLD 

Operation: 



CLD Clear decimal mode 



(Ref: 3.3.2) 



CLD 



N Z C I D V 
- 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode J 


Form 


CODE 


Bytes 


Cycles 


Implied 


CLD 


D8 


1 


2 



CLI 



CLI Clear interrupt disable bit 



CLI 



Operation 


0-^1 


(Ref: 3.2.2) 


N H 


C I D V 
- - - 






Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 

Cycles 




Implied 


CLI 


58 


1 


2 



B-10 



ClY CLV Clear overflow flag ClY 

Operation: V N^CIDV 



(Ref: 3.6.1) 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Implied 


CLV 


B8 


1 


2 



CMP 

Operation: A - M 



CMP Compare memory and accumulator 



CMP 



(Ref: 4.2.1) 



N Z C I D V 
/ / / 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Immediate 


CMP #Oper 


C9 


2 


2 


Zero Page 


CMP Oper 


C5 


2 


3 


Zero Page, X 


CMP Oper, X 


D5 


2 


4 


Absolute 


CMP Oper 


CD 


3 


4 


Absolute, X 


CMP Oper, X 


DD 


3 


4* 


Absolute, Y 


CMP Oper. Y 


D9 


3 


4* 


(Indirect. X) 


CMP (Oper, X) 


CI 


2 


6 


(Indirect), Y 


CMP (Oper) , Y 


Dl 


2 


5* 



* Add 1 if page boundary is crossed. 



B-11 



CPX 

Operation: X 



CPX Compare Memory and Index X 



(Ref: 7.8) 



CPX 1 



N Z C I D V 

/ / / 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Immediate 


CPX #Oper 


E0 


2 


2 


Zero Page 


CPX Oper 


E4 


2 


3 


Absolute 


CPX Oper 


EC 


3 





CPY 

Operation: Y - M 



CPY Compare memory and index Y 



(Ref: 7.9) 



CPY 



N Z C I D V 
/ / / 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 

Cycles 


Immediate 


CPY #Oper 


C0 


2 


2 


Zero Page 


CPY Oper 


CA 


2 


3 


Absolute 


CPY Oper 


CC 


3 


A 



B-12 



DEC 

Operation: M - 1 ^ M 



DEC Decrement memory by one 



(Ref: 10.8) 



DEC 



N a C I D V 

/ / 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Zero Page 


DEC Oper 


C6 


2 


5 


Zero Page, X 


DEC Oper, X 


D6 


2 


6 


Absolute 


DEC Oper 


CE 


3 


6 


Absolute, X 


DEC Oper, X 


DE 


3 


7 



DEX 

Operation: X - I X 



DEX Decrement index X by one 
(Ref: 7.6) 



DEX 



N a C I D V 

/ / 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Implied 


DEX 


CA 


1 


2 



B-13 



DEY 



DEY Decrement index Y by one 



DEY 



Operation 


Y - 1 Y 


(Ref: 7.7) 


N Z 
/ / 


C I D V 






Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 

Cycles 




Implied 


DEY 


88 


1 


2 



EOR 

Operation: A -V M 



EOR "Exclusive-Or" memory with accumulator 
A N Z C I D V 

/ / 

(Ref: 2.2.4.3) 



EOR 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Immediate 


EOR #Oper 


49 


2 


2 


Zero Page 


EOR Oper 


45 


2 


3 


Zero Page, X 


EOR Oper, X 


55 


2 


4 


Absolute 


EOR Oper 


4D 


3 


4 


Absolute* X 


EOR Oper, X 


5D 


3 


4* 


Absolute , Y 


EOR Oper, Y 


59 


3 


4* 


(Indirect, X) 


EOR (Oper, X) 


41 


2 


6 


(Indirect) ,Y 


EOR (Oper) , Y 


51 


2 


5* 



* Add 1 if page boundary is crossed. 



B-14 



INC 



INC Increment memory by one 



INC 



: M + 1 M 




N a 


C I D V 






(Ref: 10.7) 


/ / 






Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Zero Page 


INC Oper 


E6 


2 


5 


Zero Page, X 


INC Oper, X 


F6 


2 


6 


Absolute 


INC Oper 


EE 


3 


6 


Absolute, X 


INC Oper, X 


FE 


3 


7 



INX 

Operation 


: X + I X 


INX Increment Index X by one 
(Ref: 7.4) 


N a 

/ / 


C I D V 


INX 




Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 




Implied 


INX 


E8 


1 


2 



B-15 



INY 



INY Increment Index Y by one 



INY 



Operation 


: Y + 1 Y 


(Ref: 7.5) 


N Z 
/ / 


C I D V 






Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 




Implied 


INY 


C8 


1 


2 



JMP 



JMP Jump to new location 



JMPi 

1 



: (PC + 1) PCL 
(PC + 2) PCH 


(Ref: 4.0.2) 
(Ref: 9.8.1) 


N Z 


C 1 D V 




Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 

Cycles 


Absolute 


JMP Oper 


4C 


3 


3 


Indirect 


JMP (Oper) 


6C 


3 


5 



JSR JSR Jump to new location saving return address 

Operation; PC + 2 +, (PC + 1) PCL N 3 C I D V 

(PC + 2) PCH 

(Ref: 8.1) 



JSR 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Absolute 


JSR Oper 


20 


3 


6 



IDA 

Operation: M A 



LDA Load accumulator with memory 



(Ref: 2.1.1) 



LDA 



N a C I D V 

/ / 



I 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Immediate 


LDA # Oper 


A9 


2 


2 


Zero Page 


LDA Oper 


A5 


2 


3 


Zero Page, X 


LDA Oper, X 


B5 


2 


4 


Absolute 


LDA Oper 


AD 


3 


4 


Absolute, X 


LDA Oper, X 


BD 


3 


4* 


Absolute, Y 


LDA Oper, Y 


B9 


3 


4* 


(Indirect, X) 


LDA (Oper, X) 


Al 


2 


6 


(Indirect) , Y 


LDA (Oper) , Y 


Bl 


2 


5* 



B-16 



* Add 1 if page boundary is crossed. 

B-17 



LDX 

Operation : M 



LDX Load index X with memory 



LDX 



M X 




N Z 


C I D V 






(Ref: 7.0) 


/ / 






Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Immediate 


LDX // Oper 


A2 


2 


2 


Zero Page 


LDX Oper 


A6 


2 


3 


Zero Page, Y 


LDX Oper, Y 


B6 


2 




Absolute 


LDX Oper 


AE 


3 




Absolute, Y 


LDX Oper, Y 


BE 


3 


4* 



* Add 1 when page boundary is crossed. 



LDY 

Operation: M Y 



LDY Load index Y with memory 



(Ref: 7.1) 



LDY^ 



N a C I D V 

/ / 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Immediate 


LDY #Oper 


A0 


2 


2 


Zero Page 


LDY Oper 


A4 


2 


3 


Zero Page, X 


LDY Oper, X 


BA 


2 




Absolute 


LDY Oper 


AC 


3 


4 


Absolute, X 


LDY Oper, X 


BC 


3 


4* 



* Add 1 when page boundary is crossed. 



ISR 

Operation: 



LSR Shift right one bit ( memory or accumulator) 
C 

(Ref: 10.1) 



LSR 



N 2 C I D V 

8 / / 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Accumulator 


LSR A 


4A 


1 


2 


Zero Page 


LSR Oper 


46 


2 


5 


Zero Page, X 


LSR Oper, X 


56 


2 


6 


Absolute 


LSR Oper 


4E 


3 


6 


Absolute, X 


LSR Oper, X 


5E 


3 


7 



NOP NOP No operation 

Operation: No Operation (2 cycles) 



NOP 



N a C I D V 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Implied 


NOP 


EA 


1 


2 



ORA 



ORA "OR" memory with accumulator 



ORA 



A V M -V A 




N a 


C I D V 






(Ref: 2.2.4.2) 


/ / 







Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Immediate 


ORA #Oper 


09 


2 


2 


Zero Page 


ORA Oper 


05 


2 


3 


Zero Page, X 


ORA Oper, X 


15 


2 




Absolute 


ORA Oper 


0D 


3 


4 


Absolute, X 


ORA Oper, X 


ID 


3 


4* 


Absolute, Y 


ORA Oper, Y 


19 


3 


4* 


(Indirect. X) 


ORA (Oper, X) 


01 


2 


6 


(Indirect), Y 


ORA (Oper), Y 


11 


2 


5* 



* Add 1 on page crossing 



B-20 



PHP 



PHP Push processor status on stack 



PHP 



: P+ 


(Ref: 8.11) 




C I D V 




Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Implied 


PHP 


08 


1 


3 



PLA 



PLA Puil accumulator from stack 



PU 



PHA 

Operation : 


A + 


PHA Push accumulator on stack 

N 2 


C I D V 


PHA i 


: Operation : A t 


(Ref: 8.6) 


N a 

/ / 


C I D V 








(Ref: 8.5) 












Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 




Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 

Bytes 


No. 
Cycles 






Implied 


PLA 


68 


1 


4 




Implied 


PHA 


48 


1 


3 











I 



B-21 



PIP 

Operation: P t 



PLP Pull processor status from stack 
(Ref: 8.12) 



N Z C I D V 
From Stack 



PIP 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Implied 


PLP 


28 


1 


4 



ROL 

Operation: j 



ROL Rotate one bit left (memory or accumulator) 



ROL 



M or A 

|7|6|5|4|3|2"yT|0'| - zny -I 



(Ref: 10.3) 



N Z C I D V 
/ / / 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Accumulator 


ROL A 


2A 


1 


2 


Zero Page 


ROL Oper 


26 


2 


5 


Zero Page, X 


ROL Oper, X 


36 


2 


6 


Absolute 


ROL Oper 


2E 


3 


6 


Absolute , X 


ROL Oper, X 


3E 


3 


7 



B-22 



ROR Rotate one bit right (memory or accumulator) 



ROR 



Operation: L ^ ,7^ 



/C/ 







M 


or 


A 




7 


6 


5 


4 


3 1 2 


1 


11 



(Ref: 10.4) 



N a C I D V 
/ / / 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Accumulator 


ROR A 


6A 


I 


2 


Zero Page 


ROR Oper 


66 


2 


5 


Zero Page,X 


ROR Oper,X 


76 


2 


6 


Absolute 


ROR Oper 


6E 


3 


6 


Absolute, X 


ROR Oper,X 


7E 


3 


7 



RTI 



RTI Return from interrupt 



RTI 



■] \ Operation: 


Pf PC+ 




N Z 


C I D V 








(Ref: 9.6) 


From Stack 






Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 




Implied 


RTI 


4^ 


1 


6 


i ■ RTS 




RTS Return from subroutine 




RTS 


; Operation 


PC+, PC + i-> PC 


N Z 


C I D V 








(Ref: 8.2) 










Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 




Implied 


RTS 


60 


1 


6 



B-23 



I 



SBC 

Operation : A - M 
Note: 



SBC Subtract memory from accumulator with borrow 
• C A NZCIDV 
C = Borrow (Ref: 2.2.2) ///--/ 



SBC 



SEC 



Addressing 


Assembly Language 


OP 


No . 


No . 


Mode 


Form 


CODE 


Bytes 


Cycles 


Inunediate 


SBC #Oper 


E9 


2 


2 


Zero Page 


SBC Oper 


E5 


2 


3 


Zero Page, X 


SBC Oper, X 


F5 


2 


4 


Absolute 


SBC Oper 


ED 


3 


k 


Absolute, X 


SBC Oper, X 


FD 


3 


4* 


Absolute, Y 


SBC Oper. Y 


F9 


3 


4* 


(Indirect, X) 


SBC (Oper, X) 


El 


2 


6 


(Indirect), Y 


SBC (Oper) , Y 


Fl 


L 




d 1 when page boundary is crossed. 










SEC Set carry flag 






SEC 


: 1 C 




N Z 


C I D V 






(Ref: 3.0.1) 




1 




Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Implied 


SEC 


38 


1 


2 



SED 



SEI 

Operation: 1 I 



SED Set decimal mode 



SED 



1 D 




N Z 


C I D V 






(Ref: 3.3.1) 








Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Implied 


SED 


F8 


1 


2 



SEI Set interrupt disable status 



(Ref: 3.2.1) 



SEI 



N 2 C I D V 



Addressing 


Assembly Language 


OP 


No, 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Implied 


SEI 


78 


1 


2 



B-24 



B-25 



r 



STA 

Operation : A M 



STA Store accumulator in memory 



(Ref: 2.1.2) 



STA 



N a C I D V 



Addressing 


Assembly Language 


OP 


No. 


No. 


Mode 


Form 


CODE 


Bytes 


Cycles 


Zero Page 


STA Oper 


85 


2 


3 


Zero Page , X 


STA Oper. X 


95 


2 


k 


Absolute 


STA Oper 


8D 


3 


4 


Absolute, X 


STA Oper, X 


9D 


3 


5 


Absolute, Y 


STA Oper. Y 


99 


3 


5 


(Indirect, X) 


STA (Oper. X) 


81 


2 


6 


(Indirect), Y 


STA (Oper), Y 


91 


2 


6 



STY 

Operation: Y M 



STY Store index Y in memory 



(Ref: 7.3) 



STY 



N a C I D V 



STX 

Operation : X M 



STX Store index X in memory 
(Ref: 7.2) 



N Z C I D V 



STX I 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Zero Page 


STX Oper 


86 


2 


3 


Zero Page, Y 


STX Oper, Y 


96 


2 




Absolute 


STX Oper 


8E 


3 


4 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Zero Page 


STY Oper 


84 


2 


3 


Zero Page, X 


STY Oper, X 


9A 


2 


4 


Absolute 


STY Oper 


80 


3 


4 



TAX 





TAX Transfer accumulator to index X 




TAX 


n: A X 




N a 


C I D V 






(Ref: 7.11) 


/ / 






Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Implied 


TAX 


,AA 


1 


2 



TAY 

Operation : A Y 



TAY Transfer accumulator to index Y 



TAY 



N 2 C 1 D V 

/ / 



(Ref: 7.13) 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 

Bytes 


No. 
Cycles 


Implied 


TAY 


A8 


1 


2 



TSX 

Operation : 


S X 


TSX Transfer stack pointer to index X 

N % 
/ / 

(Ref: 8.9) 


C I D V 


TSX 




Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 




Implied 


TSX 


BA 


1 


2 



TYA 



TYA Transfer index Y to accumulator 



TYA 



Operation : 


Y A 


(Ref: 7.14) 


N 2 

/ / 


C I D V 






Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 




Implied 


TYA 


98 


1 


2 



TXA 

Operation: X A 



TXA Transfer index X to accumulator 

TXA 

N a C I D V 

/ / 

(Ref: 7.12) 



TXS 



i 



1 



Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Implied 


TXA 


8A 


1 


2 


TXS 


Transfer index X to stack pointer 




TXS 


X s 


(Ref: 8.8) 


N Z 


C I D V 




Addressing 
Mode 


Assembly Language 
Form 


OP 
CODE 


No. 
Bytes 


No. 
Cycles 


Imp lied 


TXS 


9A 


1 


2 



APPENDIX C 

INSTRUCTION ADDRESSING 

MODES AND 
RELATED EXECUTION TIMES 
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APPENDIX D 



OPERATION CODE INSTRUCTION LISTING, 



HEXIDECIMAL SEQUENCE 



00 - BEOC 2.0 

01 - ORA - (Indirect, X) 21 

02 - Future Expansion 22 

03 - Future Expansion 23 

04 - Future Expansion 24 

05 - ORA - Zero Page 25 

06 - ASL - Zero Page 26 

07 - Future Expansion 27 

08 - PHP 28 

09 - ORA - Immediate 29 
0A - ASL - Accumulator 2A 
0B - Future Expansion 2B 
0C - Future Expansion 2C 
0D - ORA - Absolute 2D 
0E - ASL - Absolute 2E 
0F - Future Expansion 2F 

10 - BPL 30 

11 - ORA - (Indirect). Y 31 

12 - Future Expansion 32 

13 - Future Expansion 33 

14 - Future Expansion 34 

15 - ORA - Zero Page.X 35 

16 - ASL - Zero Page.X 36 

17 - Future Expansion 37 

18 - CLC 38 

19 - ORA - Absolute, Y 39 
lA - Future Expansion 3A 
IB - Future Expansion 3B 
IC - Future Expansion 3C 
ID - ORA - Absolute, X 3D 
IE - ASL - Absolute, X 3E 
IF - Future Expansion 3F 



JSR 

AND - (Indirect, X) 
Future Expansion 
Future Expansion 
BIT - Zero Page 
AND - Zero Page 
ROL - Zero Page 
Future Expansion 
PLP 

AND - Immediate 
ROL - Accumulator 
Future Expansion 
BIT - Absolute 
AND - Absolute 
ROL - Absolute 
Future Expansion 
BMi 

AND - (Indirect) ,Y 
Future Expansion 
Future Expansion 
Future Expansion 
AND - Zero Page,X 
ROL - Zero Page,X 
Future Expansion 
SEC 

AND - Absolute, Y 
Future Expansion 
Future Expansion 
Future Expansion 
AND - Absolute, X 
ROL - Absolute, X 
Future Expansion 



D-2 



40 - RTI 

41 - EOR - (Indirect. X) 

42 - Future Expansion 

43 - Future Expansion 

44 - Future Expansion 

45 - EOR - Zero Page 

46 - LSR - Zero Page 

47 - Future Expansion 

48 - PHA 

49 - EOR - Immediate 
4A - LSR - Accumulator 
4B - Future Expansion 
4C - JMP - Absolute 

4D - EOR - Absolute 
4E - LSR - Absolute 
4F - Future Expansion 

50 - BVC 

51 - EOR - (Indirect), Y 

52 - Future Expansion 

53 - Future Expansion 

54 - Future Expansion 

55 - EOR - Zero Page,X 

56 - LSR - Zero Page.X 

57 - Future Expansion 

58 - CLI 

59 - EOR - Absolute, Y 
5A - Future Expansion 
5B - Future Expansion 
5C - Future Expansion 
5D - EOR - Absolute, X 
5E - LSR - Absolute, X 
5F - Future Expansion 







RTS 


ox 




PiiiK, \ inairecc , 






Future Expans ion 


63 




Future Expansion 


Oh 




Future Expansion 


O J 




ADC - Zero Page 


00 




ROR - Zero Page 


o / 




Future Expansion 


00 




PLA 


by 




ADC - Immediate 


OA 




ROR - Accumulator 


oo 




Future Expansion 


fir 




jxir inairecc 


ou 




ADL — Absolute 


6E 




Ruti Ausoiuce 


6F 




r u cuL c EiXpans lun 


70 




BVS 


71 




ADC - fTnrHrprr'i Y 


72 




Fi 1 1" t ifo F vnan o ^ n 


73 




Future Expans ion 


74 




Future Expansion 


75 




r^Kj CK.XQ rage, A 


76 




RVJK ^.ero rage , a 


77 




Future Expansion 


78 




SEI 


79 




ADC - Absolute, Y 


7A 




Future Expansion 


7B 




Future Expansion 


7C 




Future Expansion 


7D 




ADC - Absolute, X 


7E 




ROR - Absolute, X 


7F 




Future Expansion 



D-3 





Future Expsnsion 


A0 - 


LDY - Immediate 


81 - 


blA \, iriQ irec c ) A/ 


Al - 


LDA - (Indirect, X) 


82 - 


Fu ture Expansion 


A2 - 


LDX - Immediate 


83 - 


FutufE Expansion 


A3 - 


Future Expansion 


Q A 


bit iiGLO irBgc 


AA - 


LDY - Zero Page 


85 - 


STA - Zero Page 


A5 - 


LDA - Zero Page 


86 - 


D i A — £«e ro r age 


A6 - 


LDX - Zero Page 


87 - 


Future Expansion 


A7 - 


Future Expansion 


88 - 


DEY 


A8 - 


TAY 


89 - 


Future Expansion 


A9 - 


LDA - Immediate 


8A - 


TXA 


AA - 


TAX 


SB - 


Future Expans ion 


AB - 


Future Expansion 


Be - 


i> i 1 *- ADSOXUte 


AC - 


LDY - Absolute 


8D - 


STA — Absolute 


AD - 


- LDA - Absolute 


ot — 


OlA AUoUXULC 


AE - 


- LDX - Absolute 


8F — 


Future Expansion 


AF - 


- Future Expansion 




BCC 


B0 • 


- BCS 


91 - 


STA - (Indirect) ,Y 


BX - 


- LDA - (Indirect) ,Y 


92 - 


Future E'xp ans ion 


B2 


- Future Expansion 


93 - 


Future Expans ion 


B3 


- Future Expansion 


94 - 


STY - Zero Page ,X 


B4 


- LDY - Zero Page,X 


95 - 


STA - Zero Page,X 


B5 


- LDA - Zero Page,X 






B6 


- LDX - Zero Page.Y 


97 - 


Future Expansion 


B7 


- Future Expansion 


98 - 


TYA 


B8 


- CLV 


99 - 


■ STA - Absolute, Y 


B9 


- LDA - Absolute, Y 


9A - 


- TXS 


BA 


- TSX 


9B - 


- Future Expansion 


BB 


- Future Expansion 


9C - 


- Future Expansion 


BC 


- LDY - Absolute. X 


9D - 


- STA - Absolute, X 


BD 


- LDA - Absolute. X 


9E - 


- Future Expansion 


BE 


- LDX - Absolute, Y 


9F - 


- Future Expansion 


BF 


- Future Expansion 



D-4 



C0 - CPY - Immediate 
CI - CMP - (Indirect, X) 
C2 - Future Expansion 
C3 - Future Expansion 
CA - CPY - Zero Page 
C5 - CMP - Zero Page 
C6 - DEC - Zero Page 
C7 - Future Expansion 
C8 - INY 

C9 - CMP - Immediate 
CA - DEX 

CB - Future Expansion 
CC - CPY - Absolute 
CD - CMP - Absolute 
CE - DEC - Absolute 
CF - Future Expansion 
D0 - BNE 

Dl - CMP - (Indirect) ,Y 
D2 - Future Expansion 
D3 - Future Expansion 
D4 - Future Expansion 
D5 - CMP - Zero Page,X 
D6 - DEC - Zero Page,X 
D7 - Future Expansion 
D8 - CLD 

D9 - CMP - Absolute, Y 
DA - Future Expansion 
DB - Future Expansion 
DC - Future Expansion 
DD - CMP - Absolute. X 
DE - DEC - Absolute, X 
DF - Future Expansion 



E0 - CPX - Immediate 
El - SBC - (Indirect. X) 
E2 - Future Expansion 
E3 - Future Expansion 
E4 - CPX - Zero Page 
E5 - SBC - Zero Page 
E6 - INC - Zero Page 
E7 - Future Expansion 
E8 - INX 

E9 - SBC - Immediate 
EA - NOP 

EB - Future Expansion 
EC - CPX - Absolute 
ED - SBC - Absolute 
EE - INC - Absolute 
EF - Future Expansion 
F0 - BEQ 

Fl - SBC - (Indirect) .Y 
F2 - Future Expansion 
F3 - Future Expansion 
F4 - Future Expansion 
F5 - SBC - Zero Page.X 
F6 - INC - Zero Page,X 
F7 - Future Expansion 
F8 - SED 

F9 - SBC - Absolute, Y 
FA - Future Expansion 
FB - Future Expansion 
FC - Future Expansion 
FD - SBC - Absolute, X 
FE - INC - Absolute, X 
FF - Future Expansion 
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APPENDIX E 

SUMMARY OF ADDRESSING MODES 



E-1 



Appendix E is intended to serve the user by serving as a reference 
for the R6500 addressing modes. Each mode of address is shown 
with a symbolic illustration of the bus status at each cycle 
during the Instruction fetch and execution. The example number 
as found in the text is provided for reference purposes. 

E.l IMFUED ADDRESSING 



Example 5.3 : Illustration of Implied Addressing 



Clock 
Cycle 

1 
2 



Address Bus 
PC 

PC + 1 



PC + 1 



Program Counter 

PC + 1 
PC + 1 



PC + 2 



Data Bus 

OP CODE 
New 

OP CODE 



New 

OP CODE 



Comments 

Fetch OP CODE 

Ignore New 
OP CODE; 
Decode Old 
OP CODE 

Fetch New 
OP CODE; 
Execute Old 
OP CODE 



E.2 IMMEDIATE ADDRESSING 



Example 5. A : Illustration of Immediate Addressing 



Clock 
Cycle 

1 

2 



Address Bus Program Counter Data Bus Comments 



PC 

PC + 1 



PC + 2 



PC + 1 
PC + 2 



PC + 3 



OP CODE 
Data 



New 

OP CODE 



Fetch OP CODE 

Fetch Data, 
Decode OP CODE 

Fetch New 
OP CODE, 
Execute Old 
OP CODE 
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E.3 ABSOLUTE ADDRESSING 



Example 5.5 : Illustration of Absolute Addressing 



Clock 
Cycle 

1 
2 



Address Bus Program Counter Data Bus Comments 



PC 

PC + 1 

PC + 2 

ADH. ADL 
PC + 3 



PC + 1 

PC + 2 

PC + 3 

PC + 3 

PC + A 



OP CODE 
ADL 

ADH 



Data 
New 

OP CODE 



Fetch OP CODE 

Fetch ADL, 
Decode OP CODE 

Fetch ADH, 
Retail ADL 

Fetch Data 

Fetch New 
OP CODE. 
Execute Old 
OP CODE 



E.4 ZERO PAGE ADDRESSING 



Example 5.6 : Illustration of Zero Page Addressing 



Clock 

Cycle Address Bus Program Counter 



PC 

PC + 1 

DO, ADL 
PC + 2 



PC + 1 
PC + 2 



PC + 2 
PC + 3 



Data Bus 

OP CODE 
ADL 

Data 
New 

OP CODE 



Comments 

Fetch OP CODE 

Fetch ADL, De- 
code OF CODE 

Fetch Data 

Fetch New 
OP CODE. Exe- 
cute Old 
OP CODE 
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E.5 RELATIVE ADDRESSING (BRANCH POSITIVE. NO CROSSING OF PAGE BOUNDARIES) 

Example 5.8 : Illustration of Relative A<idressing — Branch Positi ve 
Take; No Crossing of Page Boundaries ' 



Cycl^ 
1 



Address Bus 



0100 



0101 



0102 



0152 



Data Bus 



OP CODE 



+50 



Next 
OP CODE 



Next 
OP CODE 



External Internal 
Operation Operation 

Fetch Finish Previous Oper- 

OP CODE ation, Incrament Pro- 

gram Counter to 101 

fetch Interpret Instruction, 

Of f set Increment Program 

Counter to 102 

Fetch Next Check Flags, Add Rela- 
OP CODE tive to PCL, Increment 

Program Counter to 103 

Fetch Next Transfer Results to 
OP CODE PCL, Increment Program 

Counter to 153 



E.6 ABSOLUTE INDEXED ADDRESSING ( WITH PAGE CROSSING) 

Step 5 is deleted and the data in step 4 are valid when no pa^e cms sin/,' occurs. 



Example 6,7 : Absolute Indexed; With Page Crossing 



Address 
Cycle Bus 



Data 
Bus 



External 
Operation 



Internal 
Operation 



0100 



OP CODE 



Fetch OP CODE 



Finish Previous 
Operation Increment 
PC to 101 



0101 



BAL 



Fetch BAL 



Interpret Instruction 
Increment PC to 102 



0102 



BAH 



Fetch BAH 



Add BAL + Index 
Increment PC to 103 



BAH , BAL 
+X 



Data 
(Ignore) 



Fetch Data 
(Data is 
ignored) 



Add BAH + Carry 



BAH+1 , 
BAL+X 



Data 



Fetch Data 



0103 



Next OP 
CODE 



Fetch Next 
OP CODE 



Finish Operation 
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E. 7 ZER O PA GE INDEXED A DDRESSING 



Example 6.8 : Illustration of Zero Page Indexing 



Cycle 
1 



Address 
Bus 



0100 



0101 



00, BAL 



00 , BAL 
+X 



Data 
Bus 



OP CODE 



BAL 



Data 
(Dis- 
carded 

Data 



External 
Operation 

Fetch OP CODE 



Fetch Base 
Address Low 
(BAL) 

Fetch 

Discarded 

Data 

Fetch Data 



Internal 
Operation 

Finish Previous 
Operation 

Interpret Instruct- 
ion 

Add: BAL + X 



0102 



Next OP 
CODE 



Fetch Next OP 
CODE 



Finish Operation 
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E.8 INDEXED INDIRECT ADDRESSING 



Example 6.10 : Illustration of Indexed Indirect Addressing 



Address Data 
Cycle Bus Bus 

1 0100 OP CODE 



0101 BAL 



O0,BAL DATA (Dis- 
carded) 

00. BAL ADL 
+ X 



External 
Operation 

Fetch OP CODE 



Fetch BAL 



Fetch Discard- 
ed DATA 



Fetch ADL 



Internal 
Operation 

Finish Previous 
Operation 

Interpret In- 
struction 

Add BAL + X 



Add 1 to BAL + X 



00 , BAL 
+ X + 1 



Fetch ADH 



Hold ADL 



6 ADH, ADL DATA 

7 0102 Next OP 



Fetch DATA 



Fetch Next OP 
CODE 



Finish Operation 
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E.9 INDIRECT INDEXED ADDRESSING (WITH PAGE CROSSING) 

Step 6 is deleted and the data in step 5 are valid when no page crossing occurs. 



Example 6.12 : Indirect Indexed Addressing (With Page Crossing) 



Cycle 
1 



Address Data 
Bus Bus 



0100 



Old 



OP CODE 



lAL 



External 
Operation 

Load OP CODE 



Fetch lAL 



Internal 
Operation 

Finish Previous 
Operation 

Interpret In- 
struction 



OO.IAL BAL 

00,XAL BAH 
+ 1 



Fetch BAL 
Fetch BAH 



Add 1 to lAL 
Add BAL to Y 



BAH, BAL DATA (Dls- 
+ Y carded) 



Fetch DATA 
(Discarded) 



Add 1 to BAH 



BAH + 1 DATA 
BAL + Y 



Fetch Data 



0102 



Next OP 
CODE 



Fetch Next OF 
CODE 



Finish This 
Operation 
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The R6500 System's family of microprocessors have a special form of 
addressing known as "Indirect". The basic operation of Indirect addres- 
sing is described in the main body of this manual. It is the intent 
of Appendix- H to acquaint the user with some of the uses and applications 
of Indirect addressing. 

The Indirect address is really an address which would have been coded 
in-line as in the case of Absolute, except for the fact that the address 
is not known at the time the user writes the program. As has been indic- 
ated several times in the body of this manual, it is significantly more 
efficient with the organization of the R6500 to assign addresses and 
implement them if the addressing structure is known; however, this is not 
always possible to accomplish. For instance, in order to minimize the 
coding of a subroutine or general-purpose set of coding, it is often 
desirable to work with a range of addressing that is impossible to cover 
in a normal index, or, in the case of subroutine, where it is necessary 
for the addresses to be variable depending on which part of the whole 
program called the address. 

It is probably this discussion which best amplifies the need for 
calculated addresses. It should be fairly obvious to the "ser that a 
general-purpose subroutine cannot contain the address of the operations. 
Therefore, instead of having the instruction LDA followed by the value 
that the programmer wants to load, in a subroutine it may be desirable to 
perform a Load A from a calculated or specified address. 

The use of the Indirect Addressing Mode is to give the user a loca- 
tion in Page Zero in which can be put the calculated address. Then the 
subroutine instruction can call this calculated address, using the form 
Load A from an address pointed to by the next byte in program sequence. 
The word "indirect" technically comes from the fact that instead of taking 
the address which is immediately following the instruction, the next value 
in program sequence is a pointer to the address . 

The Indirect pointer will be referred to from now on as lAL, because 
it is a Zero Page address and, therefore, is a low-order byte. The in- 
direct instructions are written in the form "Load A" followed by lAL. 



lAL points to an address which had been previously stored into Page Zero. 
This gives the user the flexibility of addressing anywhere in memory with 
a calculated address. However, the real value of Indirect is not simply 
in having Indirect, but in having the ability to have Indirect modified. 
This is the reason for which indirect indexed instruction is implemented 
rather than straight indirect. An example of the indirect indexed in 
subroutining is covered in Section 6.5, but it should be noted that the 
indirect indexed instruction should be employed whenever the user does 
not know the exact address at time of compilation. Although there may 
be other interesting and esoteric uses of the indirect index instruction, 
this is the most common one. 

The second form of indirect is very powerful for certain types of 
applications. Chapter 11 shows the use of tables which have pointers, 
and the advantage of running down one table of pointers until a match 
is found and then using the same index to address a second table to 
perform an operation. This is the classical stack processor type of 
architecture but it requires a special discipline at the time a program 
is originally defined. Both the indirects require a concept of memory 
management that is not obvious to the novice programmer. 

The concept of indexed indirect is that memory has to be viewed as 
a series of tables, in which access to one set of tables is accomplished 
by indexing through a list of pointers. One set of tables might be 
searched to perform some type of testing or operation; then the same 
Index is employed to process another set of pointers. This concept is 
only applicable to operations in which a variety of inputs are being 
serviced. A classical application is when several remote devices are being 
managed by the same control program. An example might be having three 
teletypes tied on to a device; each teletype is being manually controlled 
and can be under control of the user program. In this type of message- 
handling environment, the control program for the teletypes does nothing 
more than collect strings of data from the input device and then perform 
operations on the string upon seeing a control signal, usually a carriage 
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return in this case of the teletype. Because any one of the teletypes can 
be causing any one of the series of operations, this program does not lend 
itself well to the concept of absolute addressing. In fact, most of the 
subroutines which deal with the individual processing should be written 
address- independent. This normally allows the addition of more devices 
without paying any penalty in terms of programming. Therefore, this is a 
subroutine or nonabsolute type of operation in which the indirect indexed 
vould not apply, because each of the various operations use a function of 
position. In other words, one can assign a series of tables that point 
at the teletype itself, another set that points at an outgoing message 
stream, and another set that points to a series of tables which keep the 
status of the device. Each of these pointers is considered to be an 
individual address at the beginning of a string. Each string has a 
variable length. The teletype strings may consist of a three-character 
message followed by a carriage return, or a 40-character message 
followed by a carriage return. In the R6500, this system is implemented 
by developing a series of indirect pointers. Each teletype has an 
indirect pointer. Its I/O port has another indirect pointer that points 
at the put-away string, another one that points at the teletype message 
output string, another one that points at its status table. If all of the 
teletypes work in this manner, it can be seen that the coding to put data 
into the input message table is the same for all the teletypes and is 
totally independent of the teletype in which data is being stored. 

The index register X serves as a control for the tables so that if 
all tables were sequentially organized, X would point at the proper value 
for each operation. A sample operation might be: read teletype three, 
transfer the data to teletype three input register, update teletype three 
counter, check to see that teletype three is still active, and decide 
whether or not to return to signal teletype three back. The coding to 
perform each of these operations would be exactly the same as coding for 
teletype two, if the tables were organized in such a way that X was an 
index register for the pointers. 

G-4 



This is the type of string manipulation application for which indexed 
indirect was designed, and only when a program can be organized for this 
technique is the indirect used to its maximum potential. The advantages 
for organizing for this type of approach when the problem requires string 
manipulation is significant; the comprehensive I/O program is roughly 
one-half the memory and one-fourth the execution time of several other 
microprocessors which do not have this Indexed indirect feature. 
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The number 1789 is assumed by most people to mean one thousand, seven 
hundred and eighty-nine, or 1 x 10^ + 7 x 10^ + 8 x 10^ + 9 x 10°, However, 
until the number base is defined, it might mean 

1 X 163 + 7 X 162 + 8 X 16^ + 9 X ifiO 

which is hexadecimal and the form that is used in the microprocessor. 

In order to distinguish between numbers on different bases, mathema- 
ticians usually write 1789^q or just 1789 for base 10, or decimal, and 
1789^^ for base 16 for hexadecimal. Because very few computers or I/O de- 
vices allow subscripting, all hexadecimal numbers are preceded by a 
notation; thus, "1789" indictes base 10 and "$1789" indicates base 16. 

Uhy hexadecimal? This is a convenient way of representing 8 bits in 
2 digits. 

The R6500 is a byte-oriented microprocessor which means most opera- 
tions have 8-bit operations. There are 2 ways to look at 8 bits. The 
first is as 8 Individual bits in which 00001000 means that bit 3 (bit 7 to 
representation) is on and all other bits are off, or as an B-bit binary 
number in which case the value is 

Ox2^ + 0x2^ + Ox2^ + Ox2^+lx2'*+0x2^ + Qx2^ + 0x2^ = 8 
or $08. 

t 

For logic analysis purposes each bit is unique, but for arithmetic 
purposes the 8 bits are treated as a binary number. 

Binary Arithmetic Rules: 
+ 0-0 
+ 1 = 1 
1+0-1 

1+1-0 with a carry 
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Carry occurs when the resulting number is too long for the base. In 
decimal, 8 + 4 = 2 + 10. In hexadecimal, $8 + $4 = $C (see hexadecimal 
details), so that 8 + A has a carry in base 10 but not in base 16. 

Using these rules to add 8 + 2 in binary gives the following: 

00001000 8 1 X 2^ 

00000010 +2 1x2^ 
00001010 10 1 X 2^ + 1 X 2^ 

Therefore, any number from - 255 may be represented in 8 bits, and 
binary addition performed using the basic binary add equation, 
Rj - (Aj V Bj V Cj j^), where, as defined previously, V is notation for 
Exclusive-Or . 

In most applications, it is also necessary to subtract. Subtract 
operations require either a different hardware implementation or a new way 
of representing numbers. 

A combination of this is to implement a simple inverter in each bit. 
This would make 

00001100 12 

11110011 -12 

However, when subtracting 12 from 12, the result should also be 0. 

00001100 +12 

11110011 -12 

11111111 

However, if a carry Is added to the complemented number: 

1 Carry 
00001100 12 
11110011 -12 
00000000 = 

If, instead of representing -12 as the complement of 12, it is represented 
as the complement plus carry, the following is obtained: 
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11110011 = 12 

1 = Carry 

11110100 >= -12 
00001100 +12 
00000000 = 

This representation is called two's complement and represents the way that 
negative numbers are kept in the microcomputer. Below are examples of 
negative ^numbers represented in two's complement form. 



-0 




00000000 


-1 




11111111 


-2 




11111110 


-3 




11111101 


-4 




11111100 


-5 




11111011 


-6 




11111010 


-7 




11111001 


-8 




11111000 


-9 




11110111 



Hexadecimal Is the representation of numbers to the base 16. The fol- 
lowing table shows the advantages of Hex: 



Hexadecimal Binary Decimal 

0000 00 

1 0001 01 

2 0010 02 

3 OCll 03 

4 0100 OA 

5 0101 05 

6 0110 06 

7 0111 07 

8 1000 08 

9 1001 09 
A 1010 10 
B 1011 11 

' C 1100 12 

D 1101 13 

E 1110 U 

F nil 15 
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Because 16 is a multiple of 2, hexadecimal is a convenient shorthand 
for representation of A binary digits or bits. The rules on arithmetic 
also hold. 

Binary Hex 

0100 1111 4F 
+ 0110 0010 + 62 
1011 0001 Bl 

To take advantage of this shorthand, all addresses in this manual are 
shown in hexadecimal notation. It should be noted that the reader should 
learn to operate in Hex as soon as possible. Continual translation back 
Co decimal is both time-consuming and error-prone. Working in Hex and 
binary will quickly force learning of hexadecimal manipulation and the famil- 
iarity with working with this convenient representation. 



Although many microcomputer applications can successfully be accom- 
plished with binary operations, some applications are best performed in 
decimal. Although the use of one decimal character per byte would be a 
legitimate way to solve this problem, this is an inefficient use of the cap- 
ability of the 8-bit byte. 

The microprocessor allows the use of BCD representation. This 
representation is, in 4-bit form: 








0000 


1 




0001 


2 




0010 


3 




0011 


4 




0100 


5 




0101 


6 




0110 


7 




0111 


8 




1000 


9 




1001 



In BCD, the number 79 is represented: 

Binary BCD Hex 
01111001 - 79 - 79 
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The microprocessor automatically takes this into account and corrects 
for the fact that 



Decimal 

79 
■•-11 
91 



BCD 

01111001 
00010010 



Hex 

79 = 01111001 
12 = 00010010 



10010001 8B = 10001011 



The only difference between Hex and BCD representation is that the 
microprocessor automatically adjusts for the fact that BCD does not allow 
for Hex values A - F during add and subtract operations. 



The offset which follows a branch instruction is in signed two's 
complement form which means that 

$+50 = +80 = 01010000 
and $-50 = -80 = lOllOOOQ 
Proof = 00000000 

The sign for this operation is in bit 7 where an equals positive and 
a 1 equals negative. 

This bit is correct for the two's complement representation but also 
flags the microprocessor whether to carry or borrow from the address high 
byte . 

The following four examples represent the combinations of offsets which 
might occur (all notations are in hexadecimal) : 

Example H.4.1 : Forward Reference, No Page Crossing 

0105 BNE 

0106 +55 

0107 Next OP CODE 

To calculate next instruction if the branch is taken 

Offset +55 01010101 

Address Low 
for Next 

OP CODE 00000111 
5C 01011100 

with no carry, giving 015C as Che result. 



4 



Example H.4.2 : Backward Reference, No Page Crossing 

015A BNE 
015B -55 
015C Next OP CODE 



To calculate if branch is taken. 

Offset -55 AB =• 10101011 

+ Address Low for 

Next OP CODE +5C - 5C - 01011100 

07 07 00000111 

The carry is expected because of the negative offset and Is ignored, 
thus giving 0107 as the result. 



Example H.4.3 : Backward Reference If Page Boundary Crossed 

0105 BNE 

0106 -55 

0107 Next OP CODE 

To calculate if branch is taken, first calculate a low byte 

Offset -55 - AB - 10101011 

Address Low for 

Next OP CODE 07 - 07 - 00000111 
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Revised 2/79 



82 - B2 - 10110010 
There Is no carry from a negative offset; therefore, a carry must be 



made : 



-1 - -1 - FF - 11111111 
+ Address High - = 21 " OOQOQOOl 
00 00 00000000 

This gives 00 B2 as a result. 

Example H.A : Forward Reference Across Page Boundary 

OOBO BNE 
OOBl +55 
00B2 Next OP CODE 

To calculate next instruction if branch is taken. 
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Offset 

Address Low 
for Next 
OP CODE 



55 - 01010101 



B2 
07 



lOlIOOlO 
00000111 



with carry on positive number. 



+1 1 - 00000001 
Address High 00 = 00000000 
1 - 00000001 



which gives 0107. 
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